qq小游戲發(fā)布的踩坑日記(一)

資源請(qǐng)求

這陣子要發(fā)布qq小游戲了 , 沒(méi)想到剛上來(lái)就翻車了...直接請(qǐng)求資源的時(shí)候就炸了:

報(bào)錯(cuò)如下:

image.png

VM696:263 createDownloadTask:fail exceed max download connection count

查了下文檔 , 說(shuō)是一次請(qǐng)求不能超過(guò)10個(gè)...(資源超過(guò)10M的一般都超過(guò)10個(gè)吧??);

各種找, 最后還是得去微信小程序社區(qū)找方案, 兜兜轉(zhuǎn)轉(zhuǎn)又跑去github弄了個(gè)輪子,

簡(jiǎn)而言之就是做個(gè)隊(duì)列, 反正每次請(qǐng)求不能超過(guò)10個(gè),超過(guò)了就老實(shí)呆著排隊(duì),等一下再說(shuō):

最大并發(fā)限制10個(gè)

并發(fā)限制文檔傳送門

先上github上面輪子的鏈接:

wx-queue 輪子傳送門

嗯...這個(gè)輪子有點(diǎn)古老,不能直接用, 而且是用在微信小程序上面的, 所以我得改造一下,廢話少說(shuō)上代碼:

//index.js
  import q from './queue'

  function queueRequest(request, concurrency = 10) {

    if (typeof request !== 'function') {

        throw Error('request must be function')

    }

    const queue = q((task, callback) => task(callback), concurrency)

    return (obj) => {

        queue.push((callback) => {

            const originComplete = obj.complete

            obj.complete = (...args) => {

                callback()

                if (typeof originComplete === 'function') {

                    originComplete(...args)

                }

            }

            request(obj)

        })

    }

}
//在老輪子的基礎(chǔ)上,在這里加了點(diǎn)東西,因?yàn)槭莇ownloadFile不給力...qq小游戲的api跟微信部分的是通用的,你懂的,順手一起弄上去了
  function queue(concurrency) {

    const request = wx.request

    Object.defineProperty(wx, 'request', {

        get() {

            return queueRequest(request, concurrency)

        }

      })

    const QQrequest =qq.request;

    Object.defineProperty(qq, 'request', {

        get() {

            return queueRequest(QQrequest, concurrency)

        }

    })

    const wxDownloadFile = wx.downloadFile ;

    Object.defineProperty(wx, 'downloadFile', {

        get() {

            return queueRequest(wxDownloadFile, concurrency)

        }

    })

    const qqDownloadFile = qq.downloadFile ;

    Object.defineProperty(qq, 'downloadFile', {

        get() {

            return queueRequest(qqDownloadFile, concurrency)

        }

    })

  }

  export {

    queueRequest,

    queue,

  }

然后在打包好的 小游戲項(xiàng)目里面的 game.js (因?yàn)槭切∮螒?所以是game.js,如果是小程序,那就應(yīng)該是app.js)里面,加上這么兩句調(diào)用一下:

//game.js 
import { queue } from './queue/index.js'
queue(10);

嗯哼,這樣就大功告成啦,但是每次打包完都要手動(dòng)復(fù)制和加那么兩句話,實(shí)在是讓人無(wú)語(yǔ),本著程序猿懶惰的美德, 再弄個(gè)自動(dòng)復(fù)制粘貼添加兩行代碼的 python 文件:

##copyqueue.py  說(shuō)明一下, 這里是用的python3 
import os, shutil
from os import path

def copyFiles(source, target):
    if source is None or source is "":
        raise FileNotFoundError("源文件夾不能為空")
    if not path.exists(target):
        os.makedirs(target)  # 創(chuàng)建目標(biāo)文件夾
    if path.isfile(source):  # 源目錄是文件
        shutil.copy(source, target)
    else:
        target = path.join(target, path.split(source)[1])
        if not path.exists(target):
            os.makedirs(target)  # 創(chuàng)建目標(biāo)文件夾
        for file in os.listdir(source):
            newFile = path.join(source, file)
            if path.isfile(newFile):
                shutil.copy(newFile, target)
            else:
                copyFiles(newFile, target)

target = 'F:\\*****\\wechatgame' #此處星號(hào)為省略路徑,用你自己的真實(shí)路徑就好了
source = 'F:\\*****\\queue' #此處星號(hào)為省略路徑,用你自己的真實(shí)路徑就好了

copyFiles(source,target)

# coding=UTF-8
filename = 'F:\\*****\wechatGame\\game.js'#此處星號(hào)為省略路徑,用你自己的真實(shí)路徑就好了

with open(filename, 'a') as file_object:
    file_object.write("\n\n")
    file_object.write("import { queue } from './queue/index.js'\n")
    file_object.write("queue(9);\n")

嗯哼,然后打包成exe 或者直接弄個(gè)bat文件執(zhí)行以下 , 就ok了,下次雙擊就可以了~ ~(或者你其實(shí)也可以弄個(gè)插件,打包的時(shí)候順便打包進(jìn)去,時(shí)間有限我就不贅述啦);

想了想,我還是干脆把另外一個(gè)文件也copy進(jìn)來(lái)給大家好了,到時(shí)候直接復(fù)制粘貼就能用了這輪子:

//queue.js
const checkConcurrency = (concurrency = 1) => {
    if (concurrency == null) {
        concurrency = 1
    }
    else if (concurrency === 0) {
        throw new Error('Concurrency must not be zero')
    }
    return concurrency
}

const onlyOnce = (fn) => (...args) => {
    if (fn === null) {
        throw new Error('Callback was already called')
    }
    const callFn = fn
    fn = null
    return callFn(...args)
}

export default function queue(callback, concurrency) {
    checkConcurrency(concurrency)

    // 待處理的隊(duì)列
    let workers = []
    // 正在處理的隊(duì)列
    const workerList = []

    return {
        concurrency,
        push(task, callback) {
            workers.push({
                task,
                callback,
            })
            setTimeout(() => {
                this.process()
            }, 0)
        },
        process() {
            while (this.concurrency > workerList.length && workers.length) {
                const worker = workers.shift()
                workerList.push(worker)
                callback(worker.task, onlyOnce((...args) => {
                    this.pull(worker)
                    if (typeof worker.callback === 'function') {
                        worker.callback(...args)
                    }
                    this.process()
                }))
            }
        },
        pull(worker) {
            const index = workerList.indexOf(worker)
            if (index !== -1) {
                workerList.splice(index, 1)
            }
        }
    }
}
 

好了,今天先到這兒了,有什么疑問(wèn)的話歡迎隨時(shí)交流~ 謝謝!! (另外,您有空也可以 上github的原輪子主人那里點(diǎn)個(gè)星星,哈哈哈哈,飲水不忘挖井人嘛~)

祝安好~ ~ O(∩_∩)O

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市阳懂,隨后出現(xiàn)的幾起案子仑扑,更是在濱河造成了極大的恐慌洪燥,老刑警劉巖疗绣,帶你破解...
    沈念sama閱讀 211,290評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件池颈,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)锄禽,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)靴姿,“玉大人沃但,你說(shuō)我怎么就攤上這事》鹣牛” “怎么了宵晚?”我有些...
    開(kāi)封第一講書人閱讀 156,872評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)维雇。 經(jīng)常有香客問(wèn)我淤刃,道長(zhǎng),這世上最難降的妖魔是什么谆沃? 我笑而不...
    開(kāi)封第一講書人閱讀 56,415評(píng)論 1 283
  • 正文 為了忘掉前任钝凶,我火速辦了婚禮,結(jié)果婚禮上唁影,老公的妹妹穿的比我還像新娘。我一直安慰自己掂名,他們只是感情好据沈,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著饺蔑,像睡著了一般锌介。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上猾警,一...
    開(kāi)封第一講書人閱讀 49,784評(píng)論 1 290
  • 那天孔祸,我揣著相機(jī)與錄音,去河邊找鬼发皿。 笑死崔慧,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的穴墅。 我是一名探鬼主播惶室,決...
    沈念sama閱讀 38,927評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼玄货!你這毒婦竟也來(lái)了皇钞?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 37,691評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤松捉,失蹤者是張志新(化名)和其女友劉穎夹界,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體隘世,經(jīng)...
    沈念sama閱讀 44,137評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡可柿,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評(píng)論 2 326
  • 正文 我和宋清朗相戀三年鸠踪,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片趾痘。...
    茶點(diǎn)故事閱讀 38,622評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡慢哈,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出永票,到底是詐尸還是另有隱情卵贱,我是刑警寧澤,帶...
    沈念sama閱讀 34,289評(píng)論 4 329
  • 正文 年R本政府宣布侣集,位于F島的核電站键俱,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏世分。R本人自食惡果不足惜编振,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望臭埋。 院中可真熱鬧踪央,春花似錦、人聲如沸瓢阴。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)荣恐。三九已至液斜,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間叠穆,已是汗流浹背少漆。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留硼被,地道東北人示损。 一個(gè)月前我還...
    沈念sama閱讀 46,316評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像祷嘶,于是被迫代替她去往敵國(guó)和親屎媳。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容