久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

讓chatgpt將html中的圖片轉為base64方法示例

瀏覽:140日期:2022-06-01 18:51:10
目錄
  • 前言
  • 思路
  • 實現過程
    • 遞歸讀取指定目錄下的所有 html 文件路徑 htmlPaths
    • 獲取每個 html 里面的圖片 src
      • 獲取 html 字符串的所有圖片 src
      • 忽略注釋的代碼
      • 本身是 base64,則忽略
      • 忽略 Thymeleaf 語法
      • 結合起來,封裝成一個函數
  • src 轉 base64
    • 最后將新的 html 替換舊的 html
      • 性能優化
        • 總的代碼
          • 總結

            前言

            故事要從我們公司的新官網說起,新官網是叫外包做的,前后端沒有分離,對,你沒聽錯,都到了 2023 年的今天,新項目依然是前后端混在一起,堆成一座屎山,然后通過模板渲染展示網頁。

            當然,對于非研發的,技術棧咋樣都不重要,又不是不能用~

            各位看官,聽到上面的情況,是不是隱隱約約感覺到會有啥驚喜(驚嚇)

            哈,你來翻譯翻譯,什么叫驚喜?好,那我來翻譯翻譯,驚喜(bushi)就是自從新官網上線后,PV(頁面訪問量)下降了 50%。是的,你沒看錯,原因就是打開官網巨卡,一般需要 7~8s。

            就單單請求個 html,就需要耗費 7s+的時間。

            運營那邊被老板親切問候后,就跑過來找我們研發幫忙看問題,把情況說的特嚴重,唉,最終還不是得我們幫忙處理爛攤子

            那沒辦法,我們就開始分析一通,啪的一下,很快呀,就找到了加載賊慢的原因:

            • 剛才所說的服務端響應慢,那這個交給后端去搞就好(這個是重中之重)
            • 官網的圖片請求是在是太多了,而我們知道 http 請求是有次數限制的(http1.1),太多的話其他只能處于阻塞狀態

            那第二點自然是需要前端去搞了,圖片太多,導致 http 請求太多,那好辦,把小圖片轉 base64 不就好。 嗯,思路很簡單,如果是前后端分離的項目,我們一般無腦配置 webpack url-loader 的體積限制就好,或者配置 webpack5 的 asset,即在導出一個 data URI 和發送一個單獨的文件之間自動選擇:

            rules: [    {      test: /\.(png|jpe?g|svg|gif)$/,      //webpack4 start      use: [{  loader: "url-loader",  options: { limit: 10 * 1024 },},      ],      //webpack4 end      // webapack5 start      type:"asset/inline",      parser: {dataUrlCondition: {  maxSize: 10 * 1024, // 小于10k則轉為base64},      },      // webapack5 end    },  ],

            很簡單對吧,但當你想快速 cv 以上配置的時候,發現,前端代碼都是混在后端代碼里面,一堆 html 文件,html 里面又混雜著一堆的 Thymeleaf 語法(Thymeleaf 是一個跟 Velocity、FreeMarker 類似的模板引擎,它可以完全替代 JSP,JSP??都啥年代了)

            越看越不對勁,正所謂理想很豐滿,現實很骨感,唉,只能長嘆一聲。

            但沒辦法,領導可不管用啥方式,只要有個方法把 html 里面圖片小于某個指定值,如 10k,那就轉 base64,讓這些小圖片不走 http 請求。

            思路

            那么,正常的路走不通(當然也有可能有其他更快捷的方式,只是比較趕,暫時想不到更好、更簡單的方式實現),那就另辟蹊徑。

            全體流程如下:

            1. mvn clean // marven 清空輸出目錄

            2. mvn compile // marven編譯

            3. 將所有 html 的的小圖片都轉 base64

            4. mvn package // marven 打包

            以上主要重點關注第3點,既然要將所有 html 的的小圖片都轉 base64,那么自然而然可以通過寫個 node 腳本來實現,大概可以分為以下幾個步驟:

            • 遞歸讀取指定目錄下的所有 html 文件路徑 htmlPaths,這里我們假設所有 html 都放在 backend/templates 里面
            • 遍歷每個路徑,讀取對應的 html,然后通過正則匹配到每個 html 里面的所有 img 對應的 src,存放到 imgSrcs 里面
            • 遍歷每個 img 的 src,讀取 imageBuffer,并轉為 base64
            • 再將得到的 base64 替換原先的 src
            • 最后將新的 html 替換舊的 html

            上面的步驟應該比較清晰的,不過,等一下,最近 chatgpt 不是很火嗎,讓它來寫不就好~

            實現過程

            遞歸讀取指定目錄下的所有 html 文件路徑 htmlPaths

            首先判斷入口目錄的下的內容,是文件的話就判斷是否以.html 結尾,是的話則放入 htmlFilePaths,是目錄的話則遞歸遍歷,那我們來問神奇的 chatgpt:

            嗯,很不錯,第一次幾乎完美,順利拿到所有的 html 路徑

            獲取每個 html 里面的圖片 src

            自然而然想到用正則匹配來做,所以我馬上問:

            一看結果就不是我想要的,當然也是我描述的不清晰,導致 chatgpt 以為要獲取 html 文檔的圖片 src

            獲取 html 字符串的所有圖片 src

            應該問要獲取 html 字符串的,所以我接著問:

            // 定義匹配圖片標簽的正則表達式var imgRegex = /<img\s+[^>]*src=[""]([^""]*)[""][^>]*>/gi;// 要解析的HTML字符串var htmlString = "<img src="image1.jpg"> <img src="image2.jpg">";// 遍歷所有匹配到的圖片標簽并獲取其src屬性var matches;while ((matches = imgRegex.exec(htmlString)) !== null) {  var src = matches[1];  console.log(src);}

            運行后,得到的結果:

            不錯不錯,再接再厲。

            忽略注釋的代碼

            但 html 代碼可能 img 被注釋了,如 <!-- <img src='xxx.jpg'> -->,那么我們實際上沒必要去轉換,故我們讓個讓其忽略注釋的:

            那我們來試試,將其中注釋代碼中插入 img,看看是否會解析:

            // 定義匹配圖片標簽的正則表達式var imgRegex = /<img\s+[^>]*src=[""]([^""]*)[""][^>]*>/gi;// 定義匹配注釋的正則表達式var commentRegex = /<!--[\s\S]*?-->/g;// 要解析的HTML字符串var htmlString = "<!-- <img src="image3.jpg"> --> <img src="image1.jpg"> <img src="image2.jpg">";// 刪除所有注釋htmlString = htmlString.replace(commentRegex, "");// 遍歷所有匹配到的圖片標簽并獲取其src屬性var matches;while ((matches = imgRegex.exec(htmlString)) !== null) {  var src = matches[1];  console.log(src);}

            可以看到被注釋掉的 image3 不會被匹配到

            本身是 base64,則忽略

            繼續繼續,但圖片 src 可能一開始就是 base64 了,就沒必要轉了,而 base64 是 data:image 開頭的,所以我們再讓它加下條件:

            // 定義匹配圖片標簽的正則表達式var imgRegex = /<img\s+[^>]*src=[""]((?!data:image)[^""]*)[""][^>]*>/gi;// 要解析的HTML字符串var htmlString = "<img src="image1.jpg"> <img src="data:image/png;base64,iVBORw0KG..."> <img src="image2.jpg"><!-- <img src="image3.jpg"> -->";// 遍歷所有匹配到的不以 data:image 開頭的圖片標簽并獲取其src屬性var matches;while ((matches = imgRegex.exec(htmlString)) !== null) {  var src = matches[1];  console.log(src);}

            我們運行看下結果

            成功跳過了 base64 的,但是,好像沒有了忽略注釋代碼的條件,啊這。。

            所以我就讓他忽略注釋和 base64 的,但好像一直丟三落四,按下葫蘆浮起瓢,大家可以看看

            上面的注釋的被匹配到了

            注釋又又又被匹配到了,算了,我直接問如果忽略 base64,然后再組合忽略注釋的就好,組合后的代碼如下:

            const imgRegex = /<img\s+[^>]*src=[""]((?!data:image)[^""]*)[""][^>]*>/gi;// 定義匹配注釋的正則表達式const commentRegex = /<!--[\s\S]*?-->/g// 刪除所有注釋var htmlString = "<img src="image1.jpg"> <img src="data:image/png;base64,iVBORw0KG..."> <img src="image2.jpg"><!-- <img src="image3.jpg"> -->";htmlString = htmlString.replace(commentRegex, "")// 遍歷所有匹配到的圖片標簽并獲取其src屬性const imgSrcs = []let matches;while ((matches = imgRegex.exec(htmlString)) !== null) {const src = matches[1];imgSrcs.push(src)}console.log(imgSrcs)

            忽略 Thymeleaf 語法

            還有個問題,img 的 src 可能是通過服務端渲染導入的,那么我們要忽略掉,大致語法為 <img th:src="${t.imgUrl1}" />,也就是以 th:開頭的

            // 定義匹配圖片標簽的正則表達式var imgRegex = /<img\s+[^>]*src=[""]((?!data:image|@{)(?!\s*th:src)[^""]*)[""][^>]*>/gi;// 要解析的HTML字符串var htmlString = "<img src="image1.jpg"> <img src="@{some/url}"> <img src="data:image/png;base64,iVBORw0KG..."> <img src="image2.jpg" th:src="@{some/other/url}">";// 遍歷所有匹配到的不以 data:image、@{ 和包含 th:src 的圖片標簽并獲取其src屬性var matches;while ((matches = imgRegex.exec(htmlString)) !== null) {  var src = matches[1];  console.log(src);}

            上面的@{可以忽略,實際上也是屬于 Thymeleaf 語法,屏蔽 th:src 即可

            結合起來,封裝成一個函數

            function getImgSrcInHtml(htmlString) {  /** 定義匹配圖片標簽的正則表達式   * 1.src中不以data:image開頭,即不以base64開頭,沒必要再轉化了   * 2.不是th:src   * 3.忽略注釋的代碼   * */  const imgRegex = /<img\s+[^>th:]*src=[""]((?!data:image)[^""]*)[""][^>]*>/gi;  // 定義匹配注釋的正則表達式  const commentRegex = /<!--[\s\S]*?-->/g  // 刪除所有注釋  htmlString = htmlString.replace(commentRegex, "")  // 遍歷所有匹配到的圖片標簽并獲取其src屬性  const imgSrcs = []  let matches;  while ((matches = imgRegex.exec(htmlString)) !== null) {    const src = matches[1];    imgSrcs.push(src)  }  return imgSrcs.filter(Boolean)}

            運行下,看下結果:

            src 轉 base64

            自此,我們拿到所有 html 里面的 src 了,那么判斷下是否小于指定 size,是的話轉 base64

            獲取文件大小可通過 fs 的 statSync 來拿到對應文件的 size,如下

            /** 獲取文件大小 */function getFileSize(filePath) {  const stat = fs.statSync(filePath)  return stat.size}

            如果滿足條件則將圖片轉 base64,而圖片本身是 Buffer,所以要轉一下:

            /** 圖片轉成base64 */function imageToBase64(filePath) {  // 讀取圖片文件  const imageBuffer = fs.readFileSync(filePath)  const extname = getExtname(filePath)  // 將圖片文件轉換為 base64 編碼字符串  const base64String = Buffer.from(imageBuffer).toString("base64")  return `data:image/${extname.slice(1)};base64,${base64String}`}

            通過加上前綴data:image/${extname.slice(1)};base64,,其中 extname 是文件后綴名,通過path.extname拿到:

            /** 獲取后綴名 */function getExtname(filePath) {  return path.extname(filePath)}

            每得到一個 base64,則替換原先的 src:

            htmlString = htmlString.replace(src, imgBase64)

            最后將新的 html 替換舊的 html

            html 下滿足條件的 src 全部替換好后,就可以將新的 html 替換老的了,實際上也就是重寫回去:

            writeFile(htmlPath, htmlString)

            性能優化

            但我們發現整個過程中有兩處可以優化代碼:

            • 如果 src 大于指定尺寸,那么下次遇到直接跳過,不再獲取尺寸大小
            • 一個圖片可能被多處引用到,那么轉 base64 后,下次遇到就沒必要再轉了,直接復用即可

            針對第一點,我們可以通過聲明一個 Set,存放大于指定尺寸的 src:

            for (const src of imgSrcs) {      /** 之前已經大于了,這次遇到就直接跳過即可 */      if (imgOverSizeSet.has(src)) continue      let absoluteSrc = src      // 如果不是相對路徑,那么轉換為絕對路徑      if (!src.startsWith(".")) absoluteSrc = path.join(STATIC_PATH, src)      // 不存在或者超出限制,則不替換      if (getFileSize(absoluteSrc) &gt;= FILE_LIMIE_SIZE) {imgNotExistOrOverSizeSet.add(src)continue      }}

            針對第二點,我們可以通過聲明一個 Map,key 為 src,value 為 base64:

            /** 存imgSrc -&gt; 圖片base64 */const imgSrc2Base64Map = new Map()

            每次判斷到對應的 src 有值,則直接拿之前的 base64,不再轉化:

            let imgBase64 = imgSrc2Base64Map.get(src)if (!imgBase64) {  imgBase64 = imageToBase64(absoluteSrc)  imgSrc2Base64Map.set(src, imgBase64)}

            總的代碼

            const fs = require("fs")const path = require("path")function resolve(relativePath) {  return path.resolve(__dirname, relativePath)}/** 靜態資源路徑 */const STATIC_PATH = resolve("xxx")/** html模板路徑 */const TEMPLATE_PATH = resolve("yyy")/** 文件大小限制 10K */const FILE_LIMIE_SIZE = 1024 * 10/** 圖片轉成base64 */function imageToBase64(filePath) {  // 讀取圖片文件  const imageBuffer = fs.readFileSync(filePath)  const extname = getExtname(filePath)  // 將圖片文件轉換為 base64 編碼字符串  const base64String = Buffer.from(imageBuffer).toString("base64")  return `data:image/${extname.slice(1)};base64,${base64String}`}/** 獲取文件大小 */function getFileSize(filePath) {  const stat = fs.statSync(filePath)  return stat.size}/** 獲取后綴名 */function getExtname(filePath) {  return path.extname(filePath)}/** 獲取所有html路徑 */function getHtmlPaths(dir, filePaths = []) {  const files = fs.readdirSync(dir);  for (const file of files) {    const filePath = path.join(dir, file);    const fileStat = fs.statSync(filePath);    if (fileStat.isDirectory()) {      getHtmlPaths(filePath, filePaths);    } else if (fileStat.isFile() && getExtname(filePath) === ".html") {      filePaths.push(filePath);    }  }  return filePaths;}function readFile(filePath) {  return fs.readFileSync(filePath, "utf-8")}function writeFile(filePath, source) {  return fs.writeFileSync(filePath, source)}/** 獲取html中滿足規則的img src */function getImgSrcInHtml(htmlString) {  /** 定義匹配圖片標簽的正則表達式   * 1.src中不以data:image開頭,即不以base64開頭,沒必要再轉化了   * 2.不是th:src   * 3.忽略注釋的代碼   * */  const imgRegex = /<img\s+[^>th:]*src=[""]((?!data:image)[^""]*)[""][^>]*>/gi;  // 定義匹配注釋的正則表達式  const commentRegex = /<!--[\s\S]*?-->/g  // 刪除所有注釋  htmlString = htmlString.replace(commentRegex, "")  // 遍歷所有匹配到的圖片標簽并獲取其src屬性  const imgSrcs = []  let matches;  while ((matches = imgRegex.exec(htmlString)) !== null) {    const src = matches[1];    imgSrcs.push(src)  }  return imgSrcs.filter(Boolean)}/** 主程序 */function main() {  const htmlPaths = getHtmlPaths(TEMPLATE_PATH)  /** 存imgSrc -> 圖片base64 */  const imgSrc2Base64Map = new Map()  /** 存不存在,或者超過指定大小的img */  const imgNotExistOrOverSizeSet = new Set()  htmlPaths.forEach(htmlPath => {    let htmlString = readFile(htmlPath)    const imgSrcs = getImgSrcInHtml(htmlString)    if (!imgSrcs.length) return    for (const src of imgSrcs) {      if (imgNotExistOrOverSizeSet.has(src)) continue      let absoluteSrc = src      // console.log(imgSrcs)      // 如果不是相對路徑,那么轉換為絕對路徑      if (!src.startsWith(".")) absoluteSrc = path.join(STATIC_PATH, src)      const isExist = fs.existsSync(absoluteSrc)      if (!isExist) console.log("not isExist", src)      // 不存在或者超出限制,則不替換      if (!isExist || getFileSize(absoluteSrc) >= FILE_LIMIE_SIZE) {imgNotExistOrOverSizeSet.add(src)continue      }      let imgBase64 = imgSrc2Base64Map.get(src)      if (!imgBase64) {imgBase64 = imageToBase64(absoluteSrc)imgSrc2Base64Map.set(src, imgBase64)      }      htmlString = htmlString.replace(src, imgBase64)    }    // 替換好后,寫回    writeFile(htmlPath, htmlString)  })}main()

            總結

            因為太多的小圖片導致 http 請求阻塞,所以要把滿足條件的小圖片轉為 base64, 而前端的 html 混在在后端代碼里面,且里面混雜著 Thymeleaf 模板語法,想通過 webpack 打包的方式看起來好像不行(至少目前不知道咋辦),所以退而求其之自己寫個腳本來處理。

            大致思路就是:

            • 讀取所有 html,匹配到里面的所有 img 的 src
            • 匹配的過程中我們要忽略注釋的代碼、已經是 base64 的圖片、Thymeleaf 模板語法的,涉及到挺多的正則語法,這部分我通過調戲 chatgpt 來實現,雖然過程中不是十分完美
            • src 可能被重復用到,所以這里又可以優化為:
              • 如果 src 大于指定尺寸,那么下次遇到直接跳過,不再獲取尺寸大小
              • 一個圖片可能被多處引用到,那么轉 base64 后,下次遇到就沒必要再轉了,直接復用即可

            以上就是讓chatgpt將html中的圖片轉為base64方法示例的詳細內容,更多關于chatgpt html圖片轉base64的資料請關注其它相關文章!

            標簽: JavaScript
            主站蜘蛛池模板: 午夜网址 | 五月婷婷导航 | 亚洲情视频 | 美女视频一区 | 亚洲欧美高清 | 成人免费一区二区三区视频网站 | 青青99 | 国产乱码精品一区二区三区忘忧草 | 黄在线看 | 人人干天天操 | 日本在线视频中文字幕 | 国产精品无码久久久久 | 久久免费福利视频 | 中文字幕视频 | 玖玖在线精品 | 麻豆一区二区三区 | 国产第一区在线观看 | 一区二区在线视频 | 日韩高清国产一区在线 | 久久福利 | 成人免费视频网 | 蜜臀网| 久久蜜桃精品一区二区三区综合网 | 亚洲网在线 | 成人欧美一区二区三区 | 成人亚洲一区 | 久久一级| 欧洲精品乱码久久久久蜜桃 | 免费视频成人 | 亚洲欧美aa | 成人一级片在线观看 | 黄色小视频在线观看 | 欧美麻豆 | 91电影在线观看 | 亚洲人成网站999久久久综合 | 精品一区二区三区四区五区 | 国产视频网 | 天堂国产 | 成人免费视频观看视频 | 国产伦精品一区二区三区照片91 | 欧美精品一区二区三区蜜桃视频 | 福利在线看 | 国产精品美女www爽爽爽动态图 | 免费国产视频在线观看 | 亚洲国产一区二区三区在线观看 | 日韩成人精品在线观看 | 久久精品一区二区三区四区 | 黄色免费高清视频 | 黄色直接看 | 色吧欧美 | 五月天在线婷婷 | 国产精品日韩欧美一区二区三区 | 日韩免费精品视频 | av免费看在线 | 精品亚洲视频在线观看 | 国产精品久久一区二区三区 | 一级黄色爱爱视频 | 天天操天天干视频 | 精品久久久久久亚洲综合网 | xxxx免费视频 | 久久精品一区二区三区四区 | 国产一级黄片毛片 | 色无欲天天天影视综合网 | 无码一区二区三区视频 | 99热在线播放 | 亚洲国产精品久久久久久 | 日本黄色片免费 | 狠狠天天| 色橹橹欧美在线观看视频高清 | 亚洲精选一区 | 国产欧美精品一区二区三区 | 欧美精品一区二区三区在线播放 | 国产传媒一区 | 亚洲国产精品久久久久秋霞不卡 | av观看免费 | 中文字幕 视频一区 | 日韩精品久久 | 人人爱干 | 日韩在线视频观看 | 97成人在线 | 亚洲精品午夜 | 久久久国产精品入口麻豆 | 亚洲视频在线播放 | 国产精品免费av | 亚洲精品成人久久久 | 视频一区二区中文字幕 | 九九天堂 | 亚洲欧美精品久久 | 久久综合狠狠综合久久 | 亚洲网站色 | 欧美在线观看视频 | 国产精品三级在线 | 日韩城人免费 | 免费一区二区三区 | 91中文在线观看 | 精品久久久久久亚洲精品 | 天天澡天天狠天天天做 | 国产精品久久嫩一区二区 免费 | 婷婷激情五月 | 欧美成人一区二区三区片免费 | 超碰人人干| 久久综合色视频 | 日批免费视频 | 中文字幕亚洲一区二区三区 | www.久| 精品久久久久av | 欧美激情精品久久久久久 | 91亚洲一区 | 欧美国产精品一区二区 | 欧美一级毛片久久99精品蜜桃 | 欧美日韩国产一区二区三区 | 成人免费视频观看视频 | 91av国产精品 | 午夜a v电影 | 色偷偷888欧美精品久久久 | 免费在线一区二区 | 久久久久久久av | 精品二三区 | 日本免费视频 | 在线观看成人小视频 | 91中文视频 | 亚洲免费a | 国产精品毛片一区视频播 | av网站在线免费看 | 秋霞电影院午夜伦 | 亚洲美女在线视频 | 欧美久久精品 | 最新免费视频 | 国产综合视频在线观看 | 欧美色阁 | 日韩一区三区 | 国产精品视频一区二区三区 | 91精品国产91久久久久久最新 | 伊人在线 | 天堂一区 | 最新国产精品 | a视频在线观看免费 | 狠久久| 天堂一区二区三区 | 日韩精品网站在线观看 | 日本手机在线视频 | 北条麻妃99精品青青久久 | 久久精品麻豆 | av在线免费观看网站 | 久久69精品久久久久久久电影好 | 激情五月综合网 | 色综合99| 国产精品丝袜视频 | 欧美激情网址 | 久久亚洲欧美日韩精品专区 | 成人在线国产 | 蜜桃视频网站在线观看 | 奇米影视奇米色777欧美 | 91福利视频导航 | 狠狠综合久久av一区二区老牛 | 亚洲精品久久久久久国产精华液 | 久久久免费电影 | 香蕉久久一区二区不卡无毒影院 | 精品福利在线视频 | 欧美成人精品一区二区男人看 | 日本久久精品一区二区 | 香蕉久久夜色精品国产使用方法 | 色视频一区二区三区 | 国产精品三级在线 | 色九九九 | 在线视频 亚洲 | 免费在线观看一级毛片 | 久久1区 | 久久成年人视频 | 日韩成人免费 | 在线观看的av | 二区三区在线观看 | 午夜精品| 特黄一级 | 日韩精品在线免费观看视频 | a级在线观看免费 | 亚洲一区在线视频 | 黄色毛片免费看 | 国产精品25p | 国产精品一区二区三区四区 | 免费观看黄a一级视频 | 在线国产区 | 九九在线视频 | 中文字幕在线综合 | 国产高潮在线观看 | 亚洲精品三级 | 成人资源在线观看 | 亚洲中国精品精华液 | 好色视频在线观看 | 国产精品久久久久无码av | 久久影视精品 | 欧美性一区二区三区 | 99久久精品免费看国产免费粉嫩 | 狠狠艹夜夜艹 | 欧美久久一区二区 | 国产精品久久久久久久久免费丝袜 | 日韩在线不卡 | 波多野结衣一区三区 | 欧美一区二区大片 | 国产精彩视频 | 亚洲一区二区视频 | 久久这里精品 | 91精品国产99久久久久久红楼 | 色香阁99久久精品久久久 | 超碰av在线 | 成人影院网站ww555久久精品 | 精品人伦一区二区三区蜜桃视频 | 成年人在线观看 | 久久丝袜| 嫩草影院网站入口 | 免费欧美 | 日韩欧美国产一区二区 | 精品久| 青青草久久爱 | 久久久国产一区二区 | wwwjizz日本 | 91看片在线观看 | 久久久久精 | 香港三级日本三级a视频 | 欧美多人在线 | 国产视频久久久 | 日韩欧美二区 | 久久国产一区二区三区 | 天天曰天天曰 | 日本久久精品一区 | 日韩不卡| 久久精品国产亚洲精品 | 国产aaaaav久久久一区二区 | 在线亚洲一区 | 精品在线一区二区三区 | 国产精品一二 | 亚洲人成中文字幕在线观看 | 欧美成人免费在线视频 | 亚洲精品视频在线免费 | 最新国产在线 | 国产色av | 国产成人综合一区二区三区 | 日韩视频一区二区三区 | 久久com| 国产精久久久久 | 亚洲一区精品在线 | 国产乱码精品一区二区三区手机版 | 中文字幕av第一页 | 久久人人网 | 亚洲一区二区三区爽爽爽爽爽 | 美女久久 | 黄色免费av | 欧洲亚洲精品久久久久 | 一区二区三区在线免费播放 | 欧美久久久久久久 | 久在线 | 精品久久久久国产免费 | 精品成人佐山爱一区二区 | 一区二区视频网站 | 一级片大全 | 精品久久久久久久久久久 | 一级毛片免费看 | 国产超碰人人模人人爽人人添 | 欧美福利一区二区三区 | 国产伦精品一区二区三区在线 | 免费av在线网站 | 99这里只有精品视频 | 久久久精品一区二区三区 | 一区二区三区自拍 | 91视频在线看 | 精品成人在线 | a亚洲精品| 色婷婷av久久久久久久 | 99伊人网| 国产欧美高清在线观看 | 国产精品综合久久 | 看亚洲a级一级毛片 | 最新av网址大全 | 国产中文区二幕区2012 | 日日摸夜夜添夜夜添亚洲女人 | 国产大学生一区 | 麻豆91在线观看 | 欧美亚洲激情 | 国偷自产一区二区免费视频 | 久视频在线观看 | 国产精产国品一二三产区视频 | 免费观看av电影 | 亚洲精品视频在线 | 国产一级大片 | 国产精品污www在线观看 | 草草草久久久 | 99热成人在线 | a在线观看| 欧美激情精品久久久久久变态 | 国产成人在线视频 | 免费看片色 | 日韩国产 | 欧美xxxx片 | 一级黄免费看 | 一级免费在线视频 | 99精品不卡 | 亚洲免费在线视频 | 久久久精品欧美 | 色就是色网站 | 国产成人99久久亚洲综合精品 | 色一色网站 | 亚洲欧美一区二区三区在线 | 欧美韩一区二区 | 亚洲精品一区二区三区在线播放 | 精品三级在线观看 | 国产成人精品在线 | 亚洲精品成人av | 久久伊人中文字幕 | 亚洲国产成人精品女人久久久 | 午夜欧美 | 天天爽夜夜春 | 一级a毛片免费 | 五月婷婷激情 | 国产精品久久嫩一区二区 免费 | 国产视频一区在线 | 亚洲欧美综合乱码精品成人网 | 99热这里有精品 | 精品国产一区二区三区四区 | 91av在线不卡| 日韩成人免费在线 | 欧美激情网 | 亚洲男人的天堂在线播放 | 国产丝袜在线 | 黄色视频a级毛片 | 成人久久久精品乱码一区二区三区 | 欧美日在线 | av在线网址观看 | 嫩草网站在线观看 | 日韩区 | 欧美日韩一二区 | 91中文字幕在线观看 | 国产精品ssss在线亚洲 | 亚洲婷婷综合网 | 日韩影院在线 | 91精品国产综合久久久久 | 国产亚洲精品精品国产亚洲综合 | 亚洲毛片| 日本成片视频 | 成人久久久久久久 | 啪啪tv网站免费入口 | 久久麻豆视频 | 麻豆精品一区二区 | www.欧美日韩 | 嫩草网站在线观看 | 精品久久久久一区二区国产 | 欧美日韩亚洲国产综合 | 日韩av在线中文字幕 | 日本一区二区精品 | 久久精品亚洲精品 | 久久久久久黄 | 精品视频免费观看 | 亚洲视频在线观看免费 | 日本亚洲欧美 | 欧美日韩午夜精品 | 精品美女在线观看视频在线观看 | 91爱爱网 | 国产黄色免费视频 | 拍拍无遮挡人做人爱视频免费观看 | 亚洲中出 | 欧美国产日韩一区 | 91视频免费看| 伊人网站在线 | jav成人av免费播放 | 亚洲第一视频网站 | 国产成人一区 | 婷婷国产 | 欧美成人精品一区二区三区 | 91一区二区三区 | 国产精品久久a | 男人天堂999| 国产精品久久久久久 | 国产99久久精品一区二区永久免费 | 国产精品久久久久久一区二区三区 | 日夜夜精品视频 | 午夜精品久久久久久99热软件 | 精品久久久久久久久久久久包黑料 | 国产精品久久久久久久久久东京 | 久久久久久国产精品高清 | 另类色| 国产成人在线一区 | 伊人网站| 国产综合视频 | 国产精品99在线观看 | 亚洲精品无 | 91精品久久久久久久久 | 可以免费看黄的网站 | 欧美一级成人欧美性视频播放 | 羞羞视频网站 | 国产精品二区三区 | 一区久久 | julia一区二区三区中文字幕 | 999视频| baoyu133. con永久免费视频 | 在线 亚洲 欧美 | 成人欧美一区二区三区视频xxx | 99re热精品视频国产免费 | 日本久久久一区二区三区 | 精品国产一区二区三区久久 | 国产免费看 | 久久国产精品免费一区二区三区 | 最新高清无码专区 | 欧美精品一区二区三区在线播放 | 青娱乐网 | 精品久久久久一区二区国产 | 欧美日韩大片在线观看 | 国产伦精品一区二区三区四区视频 | 成人国产精品一级毛片视频 | 欧美视频在线一区 | 精品一区av| 国产免费一区二区 | 国产高清一级毛片在线不卡 | 在线视频亚洲 | 亚洲理论电影在线观看 | 亚洲高清视频在线观看 | 999国内精品永久免费视频 | 国产乱码精品一区二区三区中文 | 欲色av| 欧美国产视频一区 | 国产精品永久免费视频 | 久久久国产精品 | 91视频爱爱 | 欧美黑人一级爽快片淫片高清 | 四虎中文字幕 | 成人黄色在线视频 | 久久小视频 | 日本一区二区三区中文字幕 | 免费成人高清在线视频 | 另类 综合 日韩 欧美 亚洲 | 中文字幕亚洲一区 | 羞羞视频网站在线免费观看 | 成人精品高清 | 狠狠综合 | 久久亚洲天堂 | 99精品在线 | 亚洲高清一区二区三区 | 一级二级黄色大片 | 九色porny国模私拍av | 成人av在线网 | 久久久美女 | 成人性视频免费网站 | 国产精品久久久精品 | av观看在线 | 亚洲永久免费视频 | 国产高清视频 | 久久一区 | 国产成人精品午夜视频免费 | 91在线视频播放 | www日本高清视频 | 国产高清美女一级a毛片久久 | 久久精品二区 | 精品国产一级毛片 | 欧美激情在线播放 | 日韩午夜av | 欧美综合一区 | 成人涩涩日本国产一区 | 国产精品夜夜春夜夜爽久久电影 | 精品入口麻豆88视频 | a级毛片免费高清视频 | 午夜小视频在线观看 | 欧洲成人在线视频 | 国产精品美女久久久久久久网站 | 亚洲成人av在线 | 午夜影视 | 久久精品国产亚洲 | 亚洲高清视频在线观看 | 亚洲精品久久久久久一区二区 | 精品一区二区三区在线观看视频 | 久草在线视频免费播放 | 毛片网站免费在线观看 | 在线中文字幕第一页 | 一区二区三区免费 | 亚洲高清在线观看 | 日韩一区二区视频 | 成人三级在线 | 午夜影院普通用户体验区 | 亚洲一区二区在线播放 | 精品日韩一区二区 | 国产精品福利在线 | 国内精品一区二区 | 日韩精品一区二区三区中文字幕 | 日本三级中文在线电影 | 久久久999精品视频 99国产精品久久久久久久 | 国产精品99久久久久久大便 | 国产a免费 | 在线观看精品91福利 | 午夜a v电影| 色婷婷在线视频 | 四虎影院最新网站 | 91成人一区 | 农村妇女毛片精品久久久 | 亚洲欧美久久久 | 久久久国产精品 | 91成人短视频在线观看 | 很黄很色很爽的视频 | 久久久久久亚洲国产 | 一区二区三区视频 | 日韩中文字幕一区 | 神马久久精品 | 山岸逢花在线观看无删减 | 国产精品一区二区无线 | 日韩av一区二区三区在线观看 | 超碰偷拍| 久久久久久久久久久久久久av | 国产精品99久久久久久久久久久久 | 91高清视频 | 国产午夜精品美女视频明星a级 | 五月天婷婷在线视频 | 国产超碰人人模人人爽人人添 | 欧美成人激情视频 | h免费在线 | 国产成人精品综合 | 国产精品久久久久久久久久妞妞 | 中文字幕亚洲精品 | 欧美日韩在线一区二区三区 | 欧美影 | 日本三级电影免费 | 成人在线视频观看 | 国产午夜久久 | 日韩视频一区二区三区 | 日本五月婷婷 | 在线视频日韩 | 亚洲欧美日韩另类精品一区二区三区 | 久在线| 精品日韩中文字幕 | 亚洲天堂免费 | 国产片淫级awww | 欧美精品成人一区二区三区四区 | 国产电影一区二区在线观看 | 国产亚洲欧美一区 | 久久久精 | 成人免费视频视频在线观看 免费 | 中文日韩在线 | 欧美成年视频 | 麻豆久久久9性大片 | 久久久久久久成人 | 欧美午夜精品久久久 | 亚洲综合无码一区二区 | 黄色资源网站 | 国产一区二 | 天天操网| 午夜免费片 | 日韩av电影观看 | 欧美午夜电影 | 艳妇荡乳豪妇荡淫 | 日韩视频精品 | 国产猛男猛女超爽免费视频网站 | 中文字幕 国产精品 | 午夜精品久久久久久久久久久久 | 成人国产综合 | 日穴视频在线观看 | 欧美一级一区 | 国产日韩一区二区 | 日韩精品观看 | 欧美精品入口蜜桃 | 99色资源| 亚洲国产二区 | 国产精品久久久久久久久久久久 | 国产综合精品 | 精品国产一区二区三区成人影院 | 狠狠人人 | 亚洲午夜一区 | 久久视频一区 | 亚洲国产成人在线 | 福利二区视频 | 美女久久 | 亚洲精品一区久久久久久 | 亚洲乱码国产乱码精品精 | 欧美性受 | 成人性视频在线播放 | 国产亚洲精品成人av久久ww | 9久久| 色婷婷久久久久swag精品 | 亚洲精品一二三 | 精品一区二区免费视频 | 北条麻妃99精品青青久久主播 | 国产精品美女久久 | 亚洲色图在线播放 | 久日精品 | 亚洲一区二区在线视频 | 免费av在线网站 | 国产99久久精品一区二区永久免费 | 久久久国产一区二区三区 | 精品欧美激情在线观看 | 日韩在线播放一区 | 日韩国产一区二区 | 国产精品777 | 精品国产一区二区三区成人影院 | 国产精品一区二区三区在线播放 | 在线免费观看毛片 | 久草成人网 | 欧美一区不卡 | concern超碰在线 | 欧美福利一区二区三区 | 龙珠z普通话国语版在线观看 | 欧美日韩一区在线观看 | 国产免费看 | 国产精品视频久久 | 激情综合色综合久久综合 | 午夜精品导航 | 亚洲a网| 91精品国产92 | 久久99国产精一区二区三区 | 中文字字幕在线 | 欧美综合在线观看 | 精品在线播放 | 91在线最新 | 成人精品久久 | 一区二区三区四区视频 | 91精品国产综合久久久久久丝袜 | 中文二区| 亚洲高清在线 | 中文字幕一区二区在线观看 | 午夜久久乐 | 欧美激情五月 | 激情综合色综合久久综合 |