91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

前端如何調用后臺tp6驗證碼

發布時間:2021-12-13 15:03:33 來源:億速云 閱讀:276 作者:小新 欄目:編程語言

這篇文章主要為大家展示了“前端如何調用后臺tp6驗證碼”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“前端如何調用后臺tp6驗證碼”這篇文章吧。

環境

前端:uni-app

后端:thinkphp6

在做前端登錄頁面時,想在登錄頁面調用后端thinkphp6的驗證碼功能,于是嘗試前端通過后端的api接口獲取captcha的圖片地址。嘗試的方法是設置后端的api方法getCaptcha,在方法中通過調用captcha_src()后,可以獲得圖片地址,然后再返回給前端調用,可以正常顯示驗證碼圖片。但是問題來了,登錄時總是提示驗證碼不正確。后來經過對比發現所獲得的驗證碼的sessionID與我登錄提交時的sessionID不一致,所以導致驗證不通過。

為什么前端通過img標簽的src地址指向thinkphp6的驗證碼地址時,后臺所生成的sessionID與我在當前頁面操作時所生成的sessionID不一樣呢,這個機制目前還是搞不明白。

后來看到captcha類內有直接生成驗證碼的方法create(),經測試通過api調用此方法可以生成驗證碼并且sessionID與我后續登錄時的sessionID一致,但是又遇到另一個問題,此create()方法是返回response方法的,前端的uni.request是無法獲取的,導致驗證碼圖片是無法顯示的。經過思考,確定對captcha類進行修改,把create()方法修改為另一個新的方法,該方法返回的是生成后的驗證碼的base64編碼,然后再把該字符串結果返回前端,最終前端可以正常顯示與驗證登錄了。

具體代碼如下:

1. 新增captcha類的方法createApi(),該方法其實就是create()的復制,只是把返回的修改如下:

$base64_data = 'data:image/png;base64,' . base64_encode($content);//合成圖片的base64編碼
return $base64_data;
2. api方法調用返回
public function getCaptcha(){
        $captcha = Captcha::createApi();
        return apiResultShow(config("status.success"),lang("success"),$captcha);

    }

3. 前端接收展示驗證碼

<view @click="getCaptcha()">
	<captcha-img  :captchaSrc="captchaSrc" ></captcha-img>
</view>


.......
.........
...........
.............


getCaptcha(){
				var request_data = {};
				var sign = this.sign(request_data);
				uni.request({
				    url: '/url/api/member/getCaptcha',
				    data: { 
						sign:sign
					},
					method: 'POST',
					header:{
						"Content-Security-Policy": "upgrade-insecure-requests",
						"X-Requested-With": "XMLHttpRequest",
					},
					dataType:'json',
				    success: (res) => {
						if(res.data.status == 0){
							var img_src = res.data.result;
							this.captchaSrc = img_src;
						}else{
							this.captchaSrc ="";						
						} 
				    }
				});
			},

以上是“前端如何調用后臺tp6驗證碼”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

tp6
AI

寿光市| 三台县| 穆棱市| 景德镇市| 呼伦贝尔市| 丰台区| 韩城市| 灌南县| 安陆市| 南皮县| 荃湾区| 青浦区| 文安县| 太谷县| 柳河县| 射阳县| 镇宁| 兴国县| 南召县| 博客| 游戏| 原阳县| 西峡县| 民县| 延川县| 灵石县| 会昌县| 杭锦后旗| 七台河市| 洪江市| 安庆市| 汉寿县| 普兰店市| 华亭县| 和硕县| 读书| 深水埗区| 凯里市| 鸡东县| 岫岩| 常山县|