真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Android登錄時(shí)密碼保護(hù)功能

在很多的Android項(xiàng)目中都需要用戶登錄、注冊(cè)。這樣的話在開(kāi)發(fā)中做好保護(hù)用戶密碼的工作就顯得尤為重要。這里我把自己的密碼保護(hù)方法記錄下來(lái)。

我們提供的服務(wù)有:成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作、微信公眾號(hào)開(kāi)發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、新豐ssl等。為數(shù)千家企事業(yè)單位解決了網(wǎng)站和推廣的問(wèn)題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的新豐網(wǎng)站制作公司

這是我建了一個(gè)保存密碼的文件,以便于檢查自己保存密碼或者上傳到服務(wù)器的時(shí)候密碼是否已經(jīng)被保護(hù)了。這就是當(dāng)我輸入用戶名和密碼之后點(diǎn)擊記住密碼之后

保存在SD卡上的文件,打開(kāi)之后可以明顯的看到密碼已經(jīng)被保護(hù)了。

Android登錄時(shí)密碼保護(hù)功能

下面是我的布局文件以及主程序的代碼:


  
  
   
    
    
   
   
   
    
    
   
   
  
  

package com.itcast.test03;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.ArrayList;
import java.util.List;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.ParseException;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils;
import org.json.JSONArray;
import org.json.JSONObject;
import android.os.Build;
import android.os.Bundle;
import android.os.StrictMode;
import android.annotation.SuppressLint;
import android.annotation.TargetApi;
import android.app.Activity;
import android.content.Intent;
import android.content.SharedPreferences;
import android.text.TextUtils;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnFocusChangeListener;
import android.widget.Button;
import android.widget.CheckBox;
import android.widget.EditText;
import android.widget.Toast;


public class MainActivity extends Activity implements OnClickListener {
 private EditText et_username;
 private EditText et_userPsd;
 private Button login;
 private Button signUp;
 private CheckBox save;
 private String user,pass;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);  
  setContentView(R.layout.activity_main);
  et_username = (EditText)findViewById(R.id.et_number);
  et_userPsd = (EditText)findViewById(R.id.et_password);
  login=(Button)findViewById(R.id.login);
  signUp=(Button)findViewById(R.id.signUp);
  save = (CheckBox)findViewById(R.id.save);
  save.setOnClickListener(new CheckBox.OnClickListener(){
   public void onClick(View v) {
    SharedPreferences pre = getSharedPreferences("loginvalue",
             MODE_WORLD_WRITEABLE);
    pass = MD5( et_userPsd.getText().toString());
    user = et_username.getText().toString();
    if (!pass.equals("") && !user.equals("")) {
       pre.edit().putString("username",
         et_username.getText().toString())
         .putString("password", encryptmd5(pass)).commit();
    Toast.makeText(getApplicationContext(),"保存成功!",
    Toast.LENGTH_SHORT).show();
    } else{
    Toast.makeText(getApplicationContext(),"密碼不能為空!",
    Toast.LENGTH_LONG).show();
  }
    }
  });
  login.setOnClickListener(new Button.OnClickListener() {
    
   @Override
   public void onClick(View v) {
    
   SharedPreferences sp = getSharedPreferences("loginvalue",MODE_WORLD_READABLE);
   String loginuser = sp.getString("username",null);
   String loginpass = sp.getString("password",null);
    
   user = et_username.getText().toString();
   pass = et_userPsd.getText().toString();
    
   String passmd5 = MD5(pass);
   String encryptmd5 = encryptmd5(passmd5);
    
   System.out.println("username="+ loginuser
   + "-------------password="+ loginpass);
   System.out.println("user=="+ user
   + "-------------encryptmd5=="+ encryptmd5);
   if (!user.equals("") && !pass.equals("")) {
   if (user.equals(loginuser) && encryptmd5.equals(loginpass)) {
   Intent intent = new Intent();
   intent.setClass(MainActivity.this, StudentMainActivity.class);
   MainActivity.this.startActivity(intent);
   finish();
   } else{
   Toast.makeText(getApplicationContext(),"密碼是錯(cuò)誤的!",
   Toast.LENGTH_LONG).show();
   }
   } else{
   Toast.makeText(getApplicationContext(),"密碼不能為空!",
   Toast.LENGTH_LONG).show();
   }
    
   }
    
   });
  initWidget();//
  }
 private void initWidget()
 {
  
  login.setOnClickListener(this);
  signUp.setOnClickListener(this);
  et_username.setOnFocusChangeListener(new OnFocusChangeListener()
  {

   @Override
   public void onFocusChange(View v, boolean hasFocus) {
    // TODO Auto-generated method stub
    if(!hasFocus){
     String username=et_username.getText().toString().trim();
     if(username.length()<4){
      Toast.makeText(MainActivity.this, "用戶名不能小于4個(gè)字符", Toast.LENGTH_SHORT);
     }
    }
   }
   
  });
  et_userPsd.setOnFocusChangeListener(new OnFocusChangeListener()
  {

   @Override
   public void onFocusChange(View v, boolean hasFocus) {
    // TODO Auto-generated method stub
    if(!hasFocus){
     String password=et_userPsd.getText().toString().trim();
     if(password.length()<4){
      Toast.makeText(MainActivity.this, "密碼不能小于4個(gè)字符", Toast.LENGTH_SHORT);
     }
    }
   }
   
  });
 }
 

 public void onClick(View v) {
  // TODO Auto-generated method stub
  switch(v.getId())
  {
  case R.id.login:
   if(checkEdit())
   {
    login();
   }   
   break;
  case R.id.signUp:
   Intent intent2=new Intent(MainActivity.this,SignUp.class);
   startActivity(intent2);
   break;
  }
 }
 
 private boolean checkEdit(){
  if(et_username.getText().toString().trim().equals("")){
   Toast.makeText(MainActivity.this, "用戶名不能為空", Toast.LENGTH_SHORT).show();
   Intent intent=new Intent(MainActivity.this,StudentMainActivity.class);
   startActivity(intent);
  }else if(et_userPsd.getText().toString().trim().equals("")){
   Toast.makeText(MainActivity.this, "密碼不能為空", Toast.LENGTH_SHORT).show();
  }else{
   return true;
  }
  return false;
 }
 
 private void login(){
  //這個(gè)網(wǎng)址需要改動(dòng)
  String httpUrl="http://192.168.1.102:8080/web-test/login.jsp";
  HttpPost httpRequest=new HttpPost(httpUrl);
  List params=new ArrayList();
  params.add(new BasicNameValuePair("username",et_username.getText().toString().trim()));
  params.add(new BasicNameValuePair("password",et_userPsd.getText().toString().trim()));
  HttpEntity httpentity = null;
  try {
   httpentity = new UrlEncodedFormEntity(params,"utf8");
  } catch (UnsupportedEncodingException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  httpRequest.setEntity(httpentity);
  HttpClient httpclient=new DefaultHttpClient();
  HttpResponse httpResponse = null;
  try {
   httpResponse = httpclient.execute(httpRequest);
  } catch (ClientProtocolException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (IOException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  if(httpResponse.getStatusLine().getStatusCode()==200)
  {
   String strResult = null;
   try {
    strResult = EntityUtils.toString(httpResponse.getEntity());
   } catch (ParseException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   } catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
   Toast.makeText(MainActivity.this, strResult, Toast.LENGTH_SHORT).show();
   Intent intent=new Intent(MainActivity.this,StudentMainActivity.class);
   startActivity(intent);
  }
  else
   
  {
   Toast.makeText(MainActivity.this, "登錄失??!", Toast.LENGTH_SHORT).show();
  }
  
 }
 public static String MD5(String str){ 
  MessageDigest md5 = null; 
 try {
  md5 = MessageDigest.getInstance("MD5");
 } catch (NoSuchAlgorithmException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
  return "";
 }
  char[] charArray = str.toCharArray();
  byte[] byteArray = new byte[charArray.length];
  for (int i = 0; i < charArray.length; i++) {
  byteArray[i] = (byte)charArray[i];
 }
  byte[] md5Bytes = md5.digest(byteArray);
  StringBuffer hexValue = new StringBuffer();
  for (int i = 0; i < md5Bytes.length; i++) {
  int val = ((int)md5Bytes[i])&0xff;
  if(val<16){
   hexValue.append("0");
  }
  hexValue.append(Integer.toHexString(val));
 }
  return hexValue.toString();  
 }
 public static String encryptmd5(String str){
  char[] a = str.toCharArray();
  for (int i = 0; i < a.length; i++) {
  a[i] = (char)(a[i]^'1');
 }
  String s = new String(a);
  return s;
 }
 }

添加權(quán)限:


Android登錄時(shí)密碼保護(hù)功能Android登錄時(shí)密碼保護(hù)功能

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


新聞標(biāo)題:Android登錄時(shí)密碼保護(hù)功能
本文URL:http://weahome.cn/article/gesdeo.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部