您好,登錄后才能下訂單哦!
這篇文章主要講解了“php怎么生成掃描可登錄的二維碼”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“php怎么生成掃描可登錄的二維碼”吧!
本文實例為大家分享了php網頁生成二維碼,Android客戶端掃描登錄的具體代碼,供大家參考,具體內容如下
使用了Github上具有掃碼功能的ZXing開源庫,使用了通過隨機數生成二維碼圖片網絡API,整個過程經過三步:
1.PHP網頁生成二維碼,相應隨機數存儲到數據庫中;
2.Android客戶端掃碼,攜帶username保存至隨機數對應的位置;
3.每隔一段時間,PHP通過Ajax輪詢數據庫,判斷是否為空,不為空則跳轉網頁。
具體代碼:
1. 通過隨機數生成二維碼圖片,并執行輪詢操作命令的主頁面
<html> <head> <title>qrlogin</title> <meta charset="UTF-8"/> </head> <body> <?php /** * @author Cenquanyu * @version 2016年5月12日 * */ require 'mysql_connect.php'; $randnumber = ""; for($i=0;$i<8;$i++){ $randnumber.=rand(0,9); } //將生成的隨機數保存至數據庫 mysql_query("insert into login_data (randnumber) values ('$randnumber')") ?> <img src="http://qr.liantu.com/api.php?text=<?php echo $randnumber;?>" width="300px"/> <input hidden="hidden" type="text" name="randnumber" id="randnumber"value="<?php echo $randnumber;?>"/> </body> <script> xmlHttpRequest.onreadystatechange = function(){ if(xmlHttpRequest.status == 200 && xmlHttpRequest.readyState ==4){ result = xmlHttp.responseText; if(result==true){//username不為空則跳轉頁面 window.location.href='welcome.php'; } } } } function polling(){ //執行輪詢操作 var xmlHttpRequest; if(window.XMLHttpRequest){ xmlHttpRequest = new XMLHttpRequest(); } else{ xmlHttpRequest = new ActiveXObject("Microsoft.XMLHTTP"); } randnumber = document.getElementById('randnumber').value; xmlHttpRequest.open("GET","polling.php?randnumber="+ randnumber,true); xmlHttpRequest.send(); } setInterval("polling()",1000); </script> </html>
2. 數據庫連接頁面
<?php /** * 數據庫連接文件 * @author Cenquanyu * @version 2016年5月12日 * */ $con = mysql_connect("localhost","root","") or die(mysql_error()); mysql_select_db("qr_login"); ?>
3.執行輪詢操作的頁面,username不為空則跳轉
<?php /** * @author Cenquanyu * @version 2016年5月12日 * 執行輪詢操作,查詢隨機數在數據庫中的相應位置的username字段為不為空 * 為空,則返回false,頁面不跳轉 * 不為空,則說明有用戶進行了該二維碼的掃碼登錄,頁面進行跳轉 */ require 'mysql_connect.php'; $randnumber = $_GET['randnumber']; $result = mysql_query("select * from login_data where randnumber='$randnumber'"); $row = mysql_fetch_array($result); if($row['username']!="") echo "true"; else echo "false"; ?>
4.自定義的API,對客戶端的username進行保存
<?php /** * @author Cenquanyu * @version 2016年5月12日 * 自定義API用于Android客戶端掃碼登錄,將客戶端的username保存至二維碼對應的隨機數在數據庫中的相應位置。 * 參數:username,randnumber * 無返回值 */ $randnumber = $_GET('randnumber'); $username = $_GET('username'); require 'mysql_connect.php'; mysql_query("update qr_login set username='$username' where randnumber= '$randnumber'"); ?>
5. Android客戶端執行掃碼操作的Activity
package com.Cenquanyu.qrlogin; import com.Cenquanyu.qrlogin.R; import com.zxing.activity.CaptureActivity; import android.app.Activity; import android.content.Intent; import android.graphics.Paint.Cap; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.EditText; import android.widget.Toast; /** * @author Cenquanyu * @version 2016年5月12日 * */ public class MainActivity extends Activity implements OnClickListener { private Button btnScan; private EditText etUsername; private static final String WEB_URL = "http://172.31.19.202/QRLogin/";//改成PC端相應地址 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btnScan = (Button) findViewById(R.id.btnScan); btnScan.setOnClickListener(this); etUsername = (EditText) findViewById(R.id.etUsername); } @Override public void onClick(View v) { // 掃碼操作 Intent intent = new Intent(this, CaptureActivity.class); startActivityForResult(intent, 0);//返回結果 } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); if (resultCode == Activity.RESULT_OK) { String randnumber = data.getExtras().getString("result");//客戶端掃碼后返回掃描結果,將二維碼對應的隨機數取出 String username = etUsername.getText().toString(); String url = WEB_URL + "saveUsername.php?randnumber=" + randnumber + "&username=" + username; HttpUtils.login(url);//訪問url } } }
6. 網絡請求類
package com.Cenquanyu.qrlogin; import java.io.IOException; import java.net.HttpURLConnection; import java.net.MalformedURLException; import java.net.URL; public class HttpUtils{ public static void login(final String url){ new Thread(new Runnable() { @Override public void run() { HttpURLConnection connection; try { connection = (HttpURLConnection) new URL(url).openConnection(); connection.setRequestMethod("GET"); connection.getInputStream(); } catch (Exception e) { e.printStackTrace(); } } }).start(); } }
感謝各位的閱讀,以上就是“php怎么生成掃描可登錄的二維碼”的內容了,經過本文的學習后,相信大家對php怎么生成掃描可登錄的二維碼這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。