2017-04-06 53 views
0

我试图创建一个密码生成器(随机字符串发生器),最终将发送到数据库,但是当我在活动中使用下面的代码的应用程序出现错误“的Java终止Java串随机函数发生器.lang.ArrayIndexOutOfBoundsException:长度= 67;指数= 85" 此代码应使用一个循环,以产生从字符串的字符数组返回一个随机值。创建从一个数组的Android

package com.example.zakratcliffe.androidantitheft; 

import android.content.Intent; 
import android.support.v7.app.AppCompatActivity; 
import android.os.Bundle; 
import android.view.Menu; 
import android.view.MenuItem; 
import android.view.View; 
import android.widget.Button; 
import android.widget.EditText; 
import android.widget.TextView; 

import java.util.Random; 

public class ProfileActivity extends AppCompatActivity { 


private TextView textViewUsername, textViewUserEmail; 
private EditText textEditDescription, textEditPassword; 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_profile); 

    if (!SharedPrefManager.getInstance(this).isLoggedIn()) { 
     finish(); 
     startActivity(new Intent(this, LoginActivity.class)); 
    } 

    textViewUsername = (TextView) findViewById(R.id.textViewUsername); 
    textViewUserEmail = (TextView) findViewById(R.id.textViewUseremail); 
    textEditDescription = (EditText) findViewById(R.id.editTextDescription); 
    textEditPassword = (EditText) findViewById(R.id.editTextPassword); 

    textViewUserEmail.setText(SharedPrefManager.getInstance(this).getUserEmail()); 
    textViewUsername.setText(SharedPrefManager.getInstance(this).getUsername()); 

    final Button button = (Button) findViewById(R.id.generate_button); 
    button.setOnClickListener(new View.OnClickListener() { 
     @Override 
     public void onClick(View v) { 
      String pass = Generated_pass(); 
      textEditPassword.setText(pass); 
     } 
    }); 
} 

String Generated_pass(){ 
    char[] GenPass = {'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', '@', '!', '?', '&', '%', '~'}; 
    int i = 1; 
    String GeneratedPass = ""; 
    while (i < 13){ 
     Random r = new Random(); 
     int Character = r.nextInt(66 - 0) + 66; 
     System.out.println(GenPass[Character]); 
     GeneratedPass = GeneratedPass + GenPass[Character]; 
     i++; 
    } 
    return GeneratedPass; 
} 
public void SendToDB(View v){ 
} 
@Override 
public boolean onCreateOptionsMenu(Menu menu) { 
    getMenuInflater().inflate(R.menu.menu, menu); 
    return true; 
} 

@Override 
public boolean onOptionsItemSelected(MenuItem item) { 
    switch(item.getItemId()){ 
     case R.id.menuLogout: 
      SharedPrefManager.getInstance(this).logout(); 
      finish(); 
      startActivity(new Intent(this, LoginActivity.class)); 
      break; 
    } 
    return true; 
} 
} 
+0

刚刚更新这一行:'INT字符= r.nextInt(GenPass.length );' –

回答

0

INT字符= r.nextInt(66);

代替

INT字符= r.nextInt(66 - 0)+ 66;

因为“r.nextInt(66-0)+ 66”可能会产生0到66之间的任意随机数,然后增加到66,因此该字符的值大于66,这是不可访问的阵列(具有长度66),并且因此异常ArrayIndexOutOfBoundsException异常。

或者使代码健壮,而不是硬编码66,使用方法:

while (i < 13){ 
     Random r = new Random(); 
     int Character = r.nextInt(GenPass.length); 
     System.out.println(GenPass[Character]); 
     GeneratedPass = GeneratedPass + GenPass[Character]; 
     i++; 
    } 
    return GeneratedPass; 
} 
0
String Generated_pass(){ 
    char[] GenPass = {'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 
         'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 
         'u', 'v', 'w', 'x', 'y', 'z', '1', '2', '3', '4', 
         '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 
         'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 
         'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 
         'Z', '@', '!', '?', '&', '%', '~'}; 
    int i = 1; 
    String GeneratedPass = ""; 
    int min = 0; 
    int max = 54; 
    while (i < 13){ 
     Random r = new Random(); 
     int Character =r.nextInt(max - min + i) + min; 
     System.out.println(GenPass[Character]); 
     GeneratedPass = GeneratedPass + GenPass[Character]; 
     i++; 
    } 
    return GeneratedPass; 
} 

试试这个功能