当前位置:   article > 正文

uni-app运行到浏览器跨域H5页面的跨域问题解决方案_uniapp导出h5 跨域

uniapp导出h5 跨域

官方文档对跨域的解决方案推荐:

https://ask.dcloud.net.cn/article/35267

更方便的解决方案

 

项目根目录直接创建一个vue.config.js文件,并在里面配置代理,直接上代码

 

  1. module.exports = {
  2. publicPath: './',
  3. devServer: {
  4. proxy: {
  5. '/api': {
  6. target: 'https://movie.douban.com',
  7. ws: true,
  8. changeOrigin: true,
  9. pathRewrite: {
  10. '^/api': ''
  11. }
  12. },
  13. '/bpi': {
  14. target: 'https://douban.uieee.com/',
  15. ws: true,
  16. changeOrigin: true,
  17. pathRewrite: {
  18. '^/bpi': ''
  19. }
  20. }
  21. }
  22. },
  23. pwa: {
  24. iconPaths: {
  25. favicon32: 'favicon.ico',
  26. favicon16: 'favicon.ico',
  27. appleTouchIcon: 'favicon.ico',
  28. maskIcon: 'favicon.ico',
  29. msTileImage: 'favicon.ico'
  30. }
  31. }
  32. }

  

在相关接口请求处的代码出做修改、如下:

源代码:

 

修改后:

url: 'bpi/v2/movie/top250',

 

这时候跨域问题就解决了,但是会出现另外一个问题图片无法显示报403,这个问题通过添加自定义meta标签可以解决,

图片403问题

但是怎么在uni-app里面添加自定义的meta标签呢,~

 

1.在项目根目录下新建一个html文件;

2. 复制下面的基本模板内容,到这个html文件,

3.在此基础上修改meta和引入js;

 

标准uni-app的模板:

  1. <!DOCTYPE html>
  2. <html lang="zh-CN">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6.     <!-- 额外添加下面这句话 -->
  7.      <meta name="referrer" content="no-referrer">
  8. <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
  9. <title>
  10. <%= htmlWebpackPlugin.options.title %>
  11. </title>
  12. <script>
  13. document.addEventListener('DOMContentLoaded', function() {
  14. document.documentElement.style.fontSize = document.documentElement.clientWidth / 20 + 'px'
  15. })
  16. </script>
  17. <link rel="stylesheet" href="<%= BASE_URL %>static/index.<%= VUE_APP_INDEX_CSS_HASH %>.css" />
  18. </head>
  19. <body>
  20. <noscript>
  21. <strong>Please enable JavaScript to continue.</strong>
  22. </noscript>
  23. <div id="app"></div>
  24. <!-- built files will be auto injected -->
  25. </body>
  26. </html>

  

找到新建html文件的heade处:

<meta name="referrer" content="no-referrer" /><!--页面头部添加-->

 

4.在 manifest.json->h5->template 节点中关联这个html文件的路径。找到设置,把刚才自定义的文件引入

 

 

 

这样所有的uni-app的跨域问题就迎刃而解了

 

 

参考资料:

webpack-dev-server
webpack跨域API

 

如果大家有任何疑问即可留言反馈,会在第一时间回复反馈,谢谢大家!

本人使用GSAP框架搭建的个人网站也上线啦!有兴趣可以访问 zhaohongcheng.com 查看,感谢~

本人uni-app影视项目已经重磅开源,一套代码套发布到H5、APP、小程序等多个平台!有兴趣可以访问Dcloud官方插件市场https://ext.dcloud.net.cn/plugin?id=1839 查看,感谢~

本文为Tz张无忌文章,读后有收获可以请作者喝杯咖啡,转载请文章注明出处:https://www.cnblogs.com/zhaohongcheng/

 

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号