HarmonyOS web加载本地h5页面的网络请求跨域问题

web加载本地h5的index.html页面时,axios网络请求跨域问题,如何解决?

HarmonyOS
2024-12-25 15:58:55
浏览
收藏 0
回答 1
回答 1
按赞同
/
按时间
superinsect

webview的使用过程中存在跨域的问题,目前解决跨域问题的解决方案,主要是通过拦截并自定义请求头的形式,可参考如下代码;其中的webdata 就是你返回的页面数据。

// xxx.ets
import web_webview from '@ohos.web.webview'

@Entry
@Component
struct WebComponent {
  controller: web_webview.WebviewController = new web_webview.WebviewController()
  responseweb: WebResourceResponse = new WebResourceResponse()
  heads:Header[] = new Array()
  @State webdata: string = "<!DOCTYPE html>\n" +
    "<html>\n"+
    "<head>\n"+
    "<title>intercept test</title>\n"+
    "</head>\n"+
    "<body>\n"+
    "<h1>intercept test</h1>\n"+
    "</body>\n"+
    "</html>"
  build() {
    Column() {
      Web({ src: 'www.huawei.com', controller: this.controller })
        .onInterceptRequest((event) => {
          if (event) {
            console.log('url:' + event.request.getRequestUrl())
          }
          let head1:Header = {
            headerKey:"Access-Control-Allow-Origin",
            headerValue:"*"
          }
          let head2:Header = {
            headerKey:"Cache-Control",
            headerValue:"no-cache"
          }
          let length = this.heads.push(head1)
          length = this.heads.push(head2)
          this.responseweb.setResponseHeader(this.heads)
          this.responseweb.setResponseData(this.webdata)
          this.responseweb.setResponseEncoding('utf-8')
          this.responseweb.setResponseMimeType('text/html')
          this.responseweb.setResponseCode(200)
          this.responseweb.setReasonMessage('OK')
          return this.responseweb
        })
    }
  }
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.

oninterceptrequest拦截并自定义请求头,官网参考示例:https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V5/ts-basic-components-web-V5#oninterceptrequest9

分享
微博
QQ
微信
回复
2024-12-25 17:33:25


相关问题
HarmonyOS Web组件加载本地H5文件
704浏览 • 1回复 待解决
HarmonyOS web离线加载请求问题
991浏览 • 1回复 待解决
HarmonyOS Web组件加载在线H5页面
699浏览 • 1回复 待解决
HarmonyOS 本地H5加载
640浏览 • 1回复 待解决
HarmonyOS Web本地资源加载异常
252浏览 • 1回复 待解决
HarmonyOS H5页面加载缓存机制
921浏览 • 1回复 待解决
HarmonyOS Web组件请求问题
793浏览 • 1回复 待解决
HarmonyOS h5页面缩放问题
1538浏览 • 1回复 待解决
HarmonyOS Web组件本地资源问题
325浏览 • 1回复 待解决
HarmonyOS H5页面保存图片到本地相册
529浏览 • 1回复 待解决
Web组件和h5页面如何交互?
756浏览 • 1回复 待解决
HarmonyOS web组件加载h5h5拉起摄像头
1220浏览 • 1回复 待解决