img src 或者 background:url('') 中的地址是接口, 如何設置請求頭

問題背景:

項目之前傳遞token的方式婚被,是通過cookie來傳的。(cookie中的數(shù)據(jù)默認會跟著所有請求發(fā)送)因谷歌瀏覽器80版本之后两芳,SameSite屬性默認值改為Lax后摔寨,導致不同站下的cookie寫不進去了。所以更改了傳遞token的方式怖辆,通過請求頭傳遞。設置了axios的請求頭后删顶,其他的接口訪問都沒有問題竖螃,唯有圖片這種直接通過src或者background:url()的方式。接口就加載請求了逗余,加不上請求頭特咆。

解決方案

使用原生的XMLHttpRequest對象創(chuàng)建請求

background:url()方式

//react 代碼如下
  componentDidMount () {
     // icon為請求接口地址 如:http://localhost:8080/files/download?fileName=photo/a.jpg
    const { icon } = this.props  
    this.getImage(icon)
  }
  
  getImage = (icon) => {
    let request = new XMLHttpRequest();
    request.responseType = 'blob';
    request.open('get', icon, true);
    request.setRequestHeader('Authorization', '憑證信息'); 
    request.onreadystatechange = e => {
      if (request.readyState == XMLHttpRequest.DONE && request.status == 200) { 
          // this.refElement 表示的是html中的元素
           this.refElement.style.backgroundImage= `url(${URL.createObjectURL(request.response)})` ;
        }
    };
    request.send(null);
  }

   // render中的代碼
   <span ref={ref => (this.refElement = ref)} />

img src方式

  componentDidMount () { 
    const { icon } = this.props  
    this.getImage(icon)
  } 
  getImage = (icon) => {
    let request = new XMLHttpRequest();
    request.responseType = 'blob';
    request.open('get', icon, true);
    request.setRequestHeader('Authorization', '憑證信息'); 
    request.onreadystatechange = e => {
      if (request.readyState == XMLHttpRequest.DONE && request.status == 200) { 
          this.refElement.src = URL.createObjectURL(request.response);
          this.refElement.onload = () => {
                URL.revokeObjectURL(this.refElement.src);
          } 
        }
    };
    request.send(null);
  }

   // render中的代碼
   <img  ref={ref => (this.refElement = ref)} />

注:
URL.createObjectURL()
URL.revokeObjectURL()
參考:https://segmentfault.com/a/1190000020366227?utm_source=tag-newest

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市录粱,隨后出現(xiàn)的幾起案子腻格,更是在濱河造成了極大的恐慌,老刑警劉巖啥繁,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件菜职,死亡現(xiàn)場離奇詭異,居然都是意外死亡旗闽,警方通過查閱死者的電腦和手機酬核,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來适室,“玉大人嫡意,你說我怎么就攤上這事〉妨荆” “怎么了蔬螟?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長汽畴。 經(jīng)常有香客問我旧巾,道長,這世上最難降的妖魔是什么整袁? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任菠齿,我火速辦了婚禮,結果婚禮上坐昙,老公的妹妹穿的比我還像新娘绳匀。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布疾棵。 她就那樣靜靜地躺著戈钢,像睡著了一般。 火紅的嫁衣襯著肌膚如雪是尔。 梳的紋絲不亂的頭發(fā)上殉了,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天,我揣著相機與錄音拟枚,去河邊找鬼薪铜。 笑死,一個胖子當著我的面吹牛恩溅,可吹牛的內容都是我干的隔箍。 我是一名探鬼主播,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼脚乡,長吁一口氣:“原來是場噩夢啊……” “哼蜒滩!你這毒婦竟也來了?” 一聲冷哼從身側響起奶稠,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤俯艰,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后锌订,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體竹握,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年瀑志,在試婚紗的時候發(fā)現(xiàn)自己被綠了涩搓。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡劈猪,死狀恐怖昧甘,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情战得,我是刑警寧澤充边,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站常侦,受9級特大地震影響浇冰,放射性物質發(fā)生泄漏。R本人自食惡果不足惜聋亡,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一肘习、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧坡倔,春花似錦漂佩、人聲如沸脖含。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽养葵。三九已至,卻和暖如春瘩缆,著一層夾襖步出監(jiān)牢的瞬間关拒,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工庸娱, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留着绊,地道東北人。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓涌韩,卻偏偏與公主長得像畔柔,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子臣樱,可洞房花燭夜當晚...
    茶點故事閱讀 42,828評論 2 345