2017-04-06 29 views
0

最終的にデータベースに送信するパスワードジェネレータ(ランダムストリングジェネレータ)を作成しようとしていますが、アクティビティで以下のコードを使用すると、アプリケーションはエラー "java .lang.ArrayIndexOutOfBoundsException:length = 67; index = 85 "このコードは、文字列を生成するためにループを使用して文字配列からランダム値を返す必要があります。配列からJava文字列ランダマイザを作成する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; 
} 

関連する問題