二维码(2)二维码登录原理及Android客户端示例
1.实现思路
1.1 服务器
数据库: 建立一个2维码登录的数据表,产生一个登录页时,插入一条记录X,X含将要登录的用户名字段(初始为空),2维码中的数据字段(唯一)
登录页面: 在产生的2维码中包含关键数据Y,等待用户扫描.
后台轮询页: 不断扫描数据库中的X记录,当其中的username不空时,就可以登录跳转到登录成功页面.
登录成功页面:显示登录后的内容.
1.2 客户端
客户端扫描2维码得出其中的数据Y,然后用它找到数据库中的X,后用客户端本地的用户名更新X,当服务器的后台轮询页面发现X的用户名不空时,就登录成功.
如图:
2.注意事项
客户端在更新username时,不要用get方式,最好加密处理.
3.Android客户端示例
1 import android.app.Activity; 2 import android.content.Intent; 3 import android.os.Bundle; 4 import android.view.View; 5 import android.widget.EditText; 6 7 import com.zxing.activity.CaptureActivity; 8 9 public class MainActivity extends Activity { 10 11 private EditText edtUsername; 12 13 14 //zxing 的扫描activity结束后返回它扫描的结果. 15 @Override 16 protected void onActivityResult(int requestCode, int resultCode, Intent data) { 17 if (resultCode == Activity.RESULT_OK) { 18 String randnumber = data.getExtras().getString("result"); 19 String username = edtUsername.getText().toString(); 20 // 注意事项: 客户端在更新username时,不要用get方式,最好加密处理. 21 String url = "http://192.168.1.100/qrlogin/saveUsername.php?randnumber=" + randnumber 22 + "&username=" + username; 23 HttpUtils.login(url); 24 } 25 } 26 //开始启动zxing扫描activity 27 public void onClickQrScan(View btn){ 28 Intent intent = new Intent(this,CaptureActivity.class); 29 startActivityForResult(intent,0); 30 } 31 32 @Override 33 protected void onCreate(Bundle savedInstanceState) { 34 super.onCreate(savedInstanceState); 35 setContentView(R.layout.activity_main); 36 edtUsername = (EditText) findViewById(R.id.edt_username); 37 } 38 }