pbootcms网站模板|日韩1区2区|织梦模板||网站源码|日韩1区2区|jquery建站特效-html5模板网

<legend id='vb3vt'><style id='vb3vt'><dir id='vb3vt'><q id='vb3vt'></q></dir></style></legend>
  • <tfoot id='vb3vt'></tfoot>
    <i id='vb3vt'><tr id='vb3vt'><dt id='vb3vt'><q id='vb3vt'><span id='vb3vt'><b id='vb3vt'><form id='vb3vt'><ins id='vb3vt'></ins><ul id='vb3vt'></ul><sub id='vb3vt'></sub></form><legend id='vb3vt'></legend><bdo id='vb3vt'><pre id='vb3vt'><center id='vb3vt'></center></pre></bdo></b><th id='vb3vt'></th></span></q></dt></tr></i><div class="kaciaei" id='vb3vt'><tfoot id='vb3vt'></tfoot><dl id='vb3vt'><fieldset id='vb3vt'></fieldset></dl></div>

      • <bdo id='vb3vt'></bdo><ul id='vb3vt'></ul>

      <small id='vb3vt'></small><noframes id='vb3vt'>

        Javascript 將 URL 轉換為 BASE64 圖像

        Javascript Convert an URL to a BASE64 Image(Javascript 將 URL 轉換為 BASE64 圖像)

      1. <tfoot id='ImbXM'></tfoot>
        <i id='ImbXM'><tr id='ImbXM'><dt id='ImbXM'><q id='ImbXM'><span id='ImbXM'><b id='ImbXM'><form id='ImbXM'><ins id='ImbXM'></ins><ul id='ImbXM'></ul><sub id='ImbXM'></sub></form><legend id='ImbXM'></legend><bdo id='ImbXM'><pre id='ImbXM'><center id='ImbXM'></center></pre></bdo></b><th id='ImbXM'></th></span></q></dt></tr></i><div class="oyawyiy" id='ImbXM'><tfoot id='ImbXM'></tfoot><dl id='ImbXM'><fieldset id='ImbXM'></fieldset></dl></div>

        <legend id='ImbXM'><style id='ImbXM'><dir id='ImbXM'><q id='ImbXM'></q></dir></style></legend>
            <tbody id='ImbXM'></tbody>

            <small id='ImbXM'></small><noframes id='ImbXM'>

                <bdo id='ImbXM'></bdo><ul id='ImbXM'></ul>
                1. 本文介紹了Javascript 將 URL 轉換為 BASE64 圖像的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

                  問題描述

                  我正在構建一個 Ionic2 應用程序.我正在嘗試將圖像 url 轉換為 base64 圖像.我找到了我正在嘗試使用的 this.

                  我有以下代碼:

                  var imgUrl = 'https://www.google.de/images/srpr/logo11w.png';讓 base64image = this.getBase64Image(imgUrl);控制臺.log(base64image);

                  public getBase64Image(imgUrl) {var img = new Image();img.src = imgUrl;img.setAttribute('crossOrigin', '匿名');var canvas = document.createElement("canvas");canvas.width = img.width;canvas.height = img.height;var ctx = canvas.getContext("2d");ctx.drawImage(img, 0, 0);var dataURL = canvas.toDataURL("image/png");return dataURL.replace(/^, "");}

                  但是,它會輸出以下內容:

                  <塊引用>

                  數據:,

                  我沒有收到任何錯誤,但需要的是 base64 圖像.

                  我的代碼一定不正確.誰能告訴我如何將 url 轉換為 base64 圖像?

                  謝謝

                  更新

                  感謝以下人員的反饋,我已按照他們的建議來加載圖像.現在我有以下代碼:

                  public getBase64Image(imgUrl): Promise{return new Promise<string>(resolve => {var img = new Image();img.src = imgUrl;img.setAttribute('crossOrigin', '匿名');img.onload = (() => {var canvas = document.createElement("canvas");canvas.width = img.width;canvas.height = img.height;var ctx = canvas.getContext("2d");ctx.drawImage(img, 0, 0);var dataURL = canvas.toDataURL("image/png");//console.log('UgetBase64Image.dataURL', dataURL);解析(dataURL.replace(/^, ""));});});}

                  用法:

                   let promise64: Promise;= this.getBase64Image(personModel.avatar);promise64.then((數據) => {personModel.avatar64 = 數據;});

                  當我運行 console.log 時,這似乎確實創建了一個 base64 圖像.

                  但是,我確實收到以下錯誤:

                  <塊引用>

                  錯誤:無法在HTMLCanvasElement"上執行toDataURL":可能無法導出受污染的畫布.在 HTMLImageElement.img.onload (utilityService.ts:80)

                  第 80 行:var dataURL = canvas.toDataURL("image/png");

                  我原以為以下代碼可以解決此安全問題,但無濟于事:

                  img.setAttribute('crossOrigin', 'anonymous');

                  更多信息:

                  完全錯誤:

                   <代碼>:8100/iVBORw0KGgoAAAANSUhEUgAAAbgAAAG5CAYAAAD8liEWAAAgAElEQVR4Xty9B3NkR5Ksm ... bNkFj80enI0JnJ80 + gTsx2sbrX9zhp7k1oOOPZ5K7Oh/AvN0hP6tzZ6QAAAAAElFTkSuQmCC:1 GET HTTP://本地主機:8100/iVBORw0KGgoAAAANSUhEUgAAAbgAAAG5CAYAAAD8liEWAAAgAElEQ ... t3bNkFj80enI0JnJ80 + gTsx2sbrX9zhp7k1oOOPZ5K7Oh/AvN0hP6tzZ6QAAAAAElFTkSuQmCC凈:: ERR_EMPTY_RESPONSEpolyfills.js:3 POST http://localhost:8080/jbosswildfly-1.0/person/updatetime 400(錯誤請求)e@polyfills.js:3t.scheduleTask@polyfills.js:3e.scheduleMacroTask@polyfills.js:3(匿名)@ polyfills.js:3發送@VM9549:3(匿名)@xhr_backend.js:117Observable.subscribe@Observable.js:45MapOperator.call@map.js:54Observable.subscribe@Observable.js:42(匿名)@personService.ts:141t@polyfills.js:3PersonService.updateTimeStamps@personService.ts:140(匿名)@searchjobsParent.ts:109t.invoke@polyfills.js:3onInvoke@ng_zone.js:236t.invoke@polyfills.js:3onInvoke@ng_zone.js:236t.invoke@polyfills.js:3e.run@polyfills.js:3(匿名)@ polyfills.js:3t.invokeTask@polyfills.js:3onInvokeTask@ng_zone.js:227t.invokeTask@polyfills.js:3onInvokeTask@ng_zone.js:227t.invokeTask@polyfills.js:3e.runTask@polyfills.js:3我@polyfills.js:3polyfills.js:3 GET http://localhost:8080/jbosswildfly-1.0/person/list/favouritejob/null/0/400(錯誤請求)例外:無法在HTMLCanvasElement"上執行toDataURL":可能無法導出受污染的畫布.ErrorHandler.handleError@error_handler.js:47IonicErrorHandler.handleError @ ionic-error-handler.js:56下一個@application_ref.js:272schedulerFn @ async.js:82SafeSubscriber.__tryOrUnsub@Subscriber.js:223SafeSubscriber.next@Subscriber.js:172訂閱者._next @訂閱者.js:125訂閱者.next@訂閱者.js:89Subject.next@Subject.js:55EventEmitter.emit@async.js:74NgZone.triggerError @ ng_zone.js:278onHandleError @ ng_zone.js:257t.handleError @ polyfills.js:3e.runTask@polyfills.js:3調用@polyfills.js:3error_handler.js:52 原始堆棧跟蹤:ErrorHandler.handleError@error_handler.js:52IonicErrorHandler.handleError @ ionic-error-handler.js:56下一個@application_ref.js:272schedulerFn @ async.js:82SafeSubscriber.__tryOrUnsub@Subscriber.js:223SafeSubscriber.next@Subscriber.js:172訂閱者._next @訂閱者.js:125訂閱者.next@訂閱者.js:89Subject.next@Subject.js:55EventEmitter.emit@async.js:74NgZone.triggerError @ ng_zone.js:278onHandleError @ ng_zone.js:257t.handleError @ polyfills.js:3e.runTask@polyfills.js:3調用@polyfills.js:3error_handler.js:53 錯誤:無法在HTMLCanvasElement"上執行toDataURL":可能無法導出受污染的畫布.在 HTMLImageElement.img.onload (utilityService.ts:82)在 HTMLImageElement.n [as _onload] (polyfills.js:2)在 t.invokeTask (polyfills.js:3)在 Object.onInvokeTask (ng_zone.js:227)在 t.invokeTask (polyfills.js:3)在 e.runTask (polyfills.js:3)在 HTMLImageElement.invoke (polyfills.js:3)

                  解決方案

                  當圖像完全加載時,圖像實例會觸發 onload 事件.有了這個,另一個問題是處理異步函數.為了能夠使用 getBase64Image 使用的內容,必須使用回調函數.沒有回調函數,函數返回 undefined

                  讓 base64image = this.getBase64Image(imgUrl);控制臺.log(base64image);//不明確的

                  調整功能

                  public getBase64Image(imgUrl, callback) {var img = new Image();//onload 當圖像完全加載時觸發,并且具有寬度和高度img.onload = 函數(){var canvas = document.createElement("canvas");canvas.width = img.width;canvas.height = img.height;var ctx = canvas.getContext("2d");ctx.drawImage(img, 0, 0);var dataURL = canvas.toDataURL("image/png"),dataURL = dataURL.replace(/^, "");回調(數據URL);//base64 字符串};//設置屬性和srcimg.setAttribute('crossOrigin', '匿名');//img.src = imgUrl;}

                  用法:

                  this.getBase64Image(imgUrl, function(base64image){控制臺.log(base64image);});

                  I am building an Ionic2 app. I am trying to convert an image url to a base64 image. I have found this which I am trying to make use of.

                  I have the following code:

                  var imgUrl = 'https://www.google.de/images/srpr/logo11w.png';
                  let base64image = this.getBase64Image(imgUrl);
                  console.log(base64image);
                  

                  and

                  public getBase64Image(imgUrl) {
                      var img = new Image();
                      img.src = imgUrl;
                      img.setAttribute('crossOrigin', 'anonymous');
                      var canvas = document.createElement("canvas");
                      canvas.width = img.width;
                      canvas.height = img.height;
                      var ctx = canvas.getContext("2d");
                      ctx.drawImage(img, 0, 0);
                      var dataURL = canvas.toDataURL("image/png");
                      return dataURL.replace(/^, "");
                  }
                  

                  But, it outputs the following:

                  data:,

                  I get no errors, but expect a base64 image.

                  My code must me incorrect. Can anyone please advise how to convert the url to a base64 image?

                  Thanks

                  UPDATE

                  Thank you to the feedback from the guys below, I have followed their advise to wit for the image to load. Now I have the following code:

                  public getBase64Image(imgUrl): Promise<string> {
                      return new Promise<string>(resolve => {
                          var img = new Image();
                          img.src = imgUrl;
                          img.setAttribute('crossOrigin', 'anonymous');
                          img.onload = (() => {
                              var canvas = document.createElement("canvas");
                              canvas.width = img.width;
                              canvas.height = img.height;
                              var ctx = canvas.getContext("2d");
                              ctx.drawImage(img, 0, 0);
                              var dataURL = canvas.toDataURL("image/png");
                              //console.log('UgetBase64Image.dataURL ', dataURL);
                              resolve(dataURL.replace(/^, ""));
                          });
                      });
                  }
                  

                  usage:

                                                  let promise64: Promise<string> = this.getBase64Image(personModel.avatar);
                                                  promise64.then((data) => {
                                                      personModel.avatar64 = data;
                  
                                                  });
                  

                  This does seem to create a base64 image when I run the console.log.

                  However, I do get the following error:

                  Error: Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases may not be exported.
                      at HTMLImageElement.img.onload (utilityService.ts:80)
                  

                  Line 80: var dataURL = canvas.toDataURL("image/png");

                  I would have thought the following code would resolve this security issue, but to no avail:

                  img.setAttribute('crossOrigin', 'anonymous');
                  

                  More info:

                  Full error:

                  :8100/iVBORw0KGgoAAAANSUhEUgAAAbgAAAG5CAYAAAD8liEWAAAgAElEQVR4Xty9B3NkR5Ksm…bNkFj80enI0JnJ80+gTsx2sbrX9zhp7k1oOOPZ5K7Oh/AvN0hP6tzZ6QAAAAAElFTkSuQmCC:1 GET http://localhost:8100/iVBORw0KGgoAAAANSUhEUgAAAbgAAAG5CAYAAAD8liEWAAAgAElEQ…t3bNkFj80enI0JnJ80+gTsx2sbrX9zhp7k1oOOPZ5K7Oh/AvN0hP6tzZ6QAAAAAElFTkSuQmCC net::ERR_EMPTY_RESPONSE
                  polyfills.js:3 POST http://localhost:8080/jbosswildfly-1.0/person/updatetime 400 (Bad Request)
                  e @ polyfills.js:3
                  t.scheduleTask @ polyfills.js:3
                  e.scheduleMacroTask @ polyfills.js:3
                  (anonymous) @ polyfills.js:3
                  send @ VM9549:3
                  (anonymous) @ xhr_backend.js:117
                  Observable.subscribe @ Observable.js:45
                  MapOperator.call @ map.js:54
                  Observable.subscribe @ Observable.js:42
                  (anonymous) @ personService.ts:141
                  t @ polyfills.js:3
                  PersonService.updateTimeStamps @ personService.ts:140
                  (anonymous) @ searchjobsParent.ts:109
                  t.invoke @ polyfills.js:3
                  onInvoke @ ng_zone.js:236
                  t.invoke @ polyfills.js:3
                  onInvoke @ ng_zone.js:236
                  t.invoke @ polyfills.js:3
                  e.run @ polyfills.js:3
                  (anonymous) @ polyfills.js:3
                  t.invokeTask @ polyfills.js:3
                  onInvokeTask @ ng_zone.js:227
                  t.invokeTask @ polyfills.js:3
                  onInvokeTask @ ng_zone.js:227
                  t.invokeTask @ polyfills.js:3
                  e.runTask @ polyfills.js:3
                  i @ polyfills.js:3
                  polyfills.js:3 GET http://localhost:8080/jbosswildfly-1.0/person/list/favouritejob/null/0/ 400 (Bad Request)
                  
                  EXCEPTION: Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases may not be exported.
                  ErrorHandler.handleError @ error_handler.js:47
                  IonicErrorHandler.handleError @ ionic-error-handler.js:56
                  next @ application_ref.js:272
                  schedulerFn @ async.js:82
                  SafeSubscriber.__tryOrUnsub @ Subscriber.js:223
                  SafeSubscriber.next @ Subscriber.js:172
                  Subscriber._next @ Subscriber.js:125
                  Subscriber.next @ Subscriber.js:89
                  Subject.next @ Subject.js:55
                  EventEmitter.emit @ async.js:74
                  NgZone.triggerError @ ng_zone.js:278
                  onHandleError @ ng_zone.js:257
                  t.handleError @ polyfills.js:3
                  e.runTask @ polyfills.js:3
                  invoke @ polyfills.js:3
                  error_handler.js:52 ORIGINAL STACKTRACE:
                  ErrorHandler.handleError @ error_handler.js:52
                  IonicErrorHandler.handleError @ ionic-error-handler.js:56
                  next @ application_ref.js:272
                  schedulerFn @ async.js:82
                  SafeSubscriber.__tryOrUnsub @ Subscriber.js:223
                  SafeSubscriber.next @ Subscriber.js:172
                  Subscriber._next @ Subscriber.js:125
                  Subscriber.next @ Subscriber.js:89
                  Subject.next @ Subject.js:55
                  EventEmitter.emit @ async.js:74
                  NgZone.triggerError @ ng_zone.js:278
                  onHandleError @ ng_zone.js:257
                  t.handleError @ polyfills.js:3
                  e.runTask @ polyfills.js:3
                  invoke @ polyfills.js:3
                  error_handler.js:53 Error: Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases may not be exported.
                      at HTMLImageElement.img.onload (utilityService.ts:82)
                      at HTMLImageElement.n [as _onload] (polyfills.js:2)
                      at t.invokeTask (polyfills.js:3)
                      at Object.onInvokeTask (ng_zone.js:227)
                      at t.invokeTask (polyfills.js:3)
                      at e.runTask (polyfills.js:3)
                      at HTMLImageElement.invoke (polyfills.js:3)
                  

                  解決方案

                  Image instance fires onload event when the image is fully loaded. With this, another issue comes in which is dealing asynchronous functions. To be able to use what getBase64Image uses, a callback function must be used. Without a callback function, the function returns undefined

                  let base64image = this.getBase64Image(imgUrl);
                  console.log(base64image); // undefined
                  

                  Adjusted function

                  public getBase64Image(imgUrl, callback) {
                  
                      var img = new Image();
                  
                      // onload fires when the image is fully loadded, and has width and height
                  
                      img.onload = function(){
                  
                        var canvas = document.createElement("canvas");
                        canvas.width = img.width;
                        canvas.height = img.height;
                        var ctx = canvas.getContext("2d");
                        ctx.drawImage(img, 0, 0);
                        var dataURL = canvas.toDataURL("image/png"),
                            dataURL = dataURL.replace(/^, "");
                  
                        callback(dataURL); // the base64 string
                  
                      };
                  
                      // set attributes and src 
                      img.setAttribute('crossOrigin', 'anonymous'); //
                      img.src = imgUrl;
                  
                  }
                  

                  Usage:

                  this.getBase64Image(imgUrl, function(base64image){
                       console.log(base64image);
                  });
                  

                  這篇關于Javascript 將 URL 轉換為 BASE64 圖像的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

                  【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

                  相關文檔推薦

                  Use IScroll in Angular 2 / Typescript(在 Angular 2/Typescript 中使用 IScroll)
                  anime.js not working in Ionic 3 project(Anime.js 在 Ionic 3 項目中不起作用)
                  Ionic 3 - Update Observable with Asynchronous Data(Ionic 3 - 使用異步數據更新 Observable)
                  Angular 2: file not found on local .json file(Angular 2:在本地 .json 文件中找不到文件)
                  In Ionic 2, how do I create a custom directive that uses Ionic components?(在 Ionic 2 中,如何創建使用 Ionic 組件的自定義指令?)
                  Use ViewChild for dynamic elements - Angular 2 amp; ionic 2(將 ViewChild 用于動態元素 - Angular 2 amp;離子2)
                  • <legend id='OrZDq'><style id='OrZDq'><dir id='OrZDq'><q id='OrZDq'></q></dir></style></legend>
                    <i id='OrZDq'><tr id='OrZDq'><dt id='OrZDq'><q id='OrZDq'><span id='OrZDq'><b id='OrZDq'><form id='OrZDq'><ins id='OrZDq'></ins><ul id='OrZDq'></ul><sub id='OrZDq'></sub></form><legend id='OrZDq'></legend><bdo id='OrZDq'><pre id='OrZDq'><center id='OrZDq'></center></pre></bdo></b><th id='OrZDq'></th></span></q></dt></tr></i><div class="eeuqw6i" id='OrZDq'><tfoot id='OrZDq'></tfoot><dl id='OrZDq'><fieldset id='OrZDq'></fieldset></dl></div>
                          <bdo id='OrZDq'></bdo><ul id='OrZDq'></ul>

                            <tfoot id='OrZDq'></tfoot>

                            <small id='OrZDq'></small><noframes id='OrZDq'>

                              <tbody id='OrZDq'></tbody>
                          • 主站蜘蛛池模板: 鑫达滑石-辽宁鑫达滑石集团 | 道达尔润滑油-食品级润滑油-道达尔导热油-合成导热油,深圳道达尔代理商合-深圳浩方正大官网 | 盘煤仪,盘料仪,盘点仪,堆料测量仪,便携式激光盘煤仪-中科航宇(北京)自动化工程技术有限公司 | 不锈钢水箱生产厂家_消防水箱生产厂家-河南联固供水设备有限公司 | 时代北利离心机,实验室离心机,医用离心机,低速离心机DT5-2,美国SKC采样泵-上海京工实业有限公司 工业电炉,台车式电炉_厂家-淄博申华工业电炉有限公司 | Eiafans.com_环评爱好者 环评网|环评论坛|环评报告公示网|竣工环保验收公示网|环保验收报告公示网|环保自主验收公示|环评公示网|环保公示网|注册环评工程师|环境影响评价|环评师|规划环评|环评报告|环评考试网|环评论坛 - Powered by Discuz! | TTCMS自助建站_网站建设_自助建站_免费网站_免费建站_天天向上旗下品牌 | 天津散热器_天津暖气片_天津安尼威尔散热器制造有限公司 | 步进_伺服_行星减速机,微型直流电机,大功率直流电机-淄博冠意传动机械 | 深圳成考网-深圳成人高考报名网 深圳工程师职称评定条件及流程_深圳职称评审_职称评审-职称网 | 网站优化公司_北京网站优化_抖音短视频代运营_抖音关键词seo优化排名-通则达网络 | 骨灰存放架|骨灰盒寄存架|骨灰架厂家|智慧殡葬|公墓陵园管理系统|网上祭奠|告别厅智能化-厦门慈愿科技 | 反渗透水处理设备|工业零排放|水厂设备|软化水设备|海南净水设备--海南水处理设备厂家 | 深圳南财多媒体有限公司介绍| 石牌坊价格石牌坊雕刻制作_石雕牌坊牌楼石栏杆厂家_山东嘉祥石雕有限公司 | lcd条形屏-液晶长条屏-户外广告屏-条形智能显示屏-深圳市条形智能电子有限公司 | 拼装地板,悬浮地板厂家,悬浮式拼装运动地板-石家庄博超地板科技有限公司 | 常州减速机_减速机厂家_常州市减速机厂有限公司 | 粤丰硕水性环氧地坪漆-防静电自流平厂家-环保地坪涂料代理 | 精准猎取科技资讯,高效阅读科技新闻_科技猎 | 【MBA备考网】-2024年工商管理硕士MBA院校/报考条件/培训/考试科目/提前面试/考试/学费-MBA备考网 | 书信之家_书信标准模板范文大全 最新范文网_实用的精品范文美文网 | 全自动固相萃取仪_高通量真空平行浓缩仪-勤业永为 | 柔性输送线|柔性链板|齿形链-上海赫勒输送设备有限公司首页[输送机] | 阻燃剂-氢氧化镁-氢氧化铝-沥青阻燃剂-合肥皖燃新材料 | 滚筒线,链板线,总装线,流水线-上海体能机电有限公司 | 中空玻璃生产线,玻璃加工设备,全自动封胶线,铝条折弯机,双组份打胶机,丁基胶/卧式/立式全自动涂布机,玻璃设备-山东昌盛数控设备有限公司 | 高防护蠕动泵-多通道灌装系统-高防护蠕动泵-www.bjhuiyufluid.com慧宇伟业(北京)流体设备有限公司 | 冷却塔风机厂家_静音冷却塔风机_冷却塔电机维修更换维修-广东特菱节能空调设备有限公司 | 400电话_400电话申请_866元/年_【400电话官方业务办理】-俏号网 3dmax渲染-效果图渲染-影视动画渲染-北京快渲科技有限公司 | pH污水传感器电极,溶解氧电极传感器-上海科蓝仪表科技有限公司 | 懂研帝_专业SCI论文润色机构_SCI投稿发表服务公司 | 立式硫化罐-劳保用品硫化罐-厂家直销-山东鑫泰鑫硫化罐厂家 | 玉米加工设备,玉米深加工机械,玉米糁加工设备.玉米脱皮制糁机 华豫万通粮机 | 沈阳激光机-沈阳喷码机-沈阳光纤激光打标机-沈阳co2激光打标机 | 郑州墨香品牌设计公司|品牌全案VI设计公司 | 万师讲师网-优质讲师培训师供应商,讲师认证,找讲师来万师 | 旅游规划_旅游策划_乡村旅游规划_景区规划设计_旅游规划设计公司-北京绿道联合旅游规划设计有限公司 | 桨叶搅拌机_螺旋挤压/方盒旋切造粒机厂家-无锡市鸿诚输送机械有限公司 | 杭州公司变更法人-代理记账收费价格-公司注销代办_杭州福道财务管理咨询有限公司 | 微水泥_硅藻泥_艺术涂料_艺术漆_艺术漆加盟-青岛泥之韵环保壁材 武汉EPS线条_EPS装饰线条_EPS构件_湖北博欧EPS线条厂家 |