提问人:Towfik Alrazihi 提问时间:8/15/2016 最后编辑:PhilLabTowfik Alrazihi 更新时间:9/14/2017 访问量:6817
“由于异常:java.lang.ClassNotFoundException: com.android.webview.chromium.Drp,没有 DRP 密钥”是什么意思?
What does this mean "No DRP key due to exception:java.lang.ClassNotFoundException: com.android.webview.chromium.Drp"?
问:
我正在尝试解析本地 url (http://192.168.1.94/wamp/up.php) 以在我的应用程序 android 中使用它(JSON 解析)。
mainActivity android :
package itawfik.com.myapplication;
import android.app.ProgressDialog;
import android.os.AsyncTask;
import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
public class MainActivity extends ActionBarActivity {
Button btnHit;
TextView txtJson;
ProgressDialog pd;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
btnHit = (Button) findViewById(R.id.btnHit);
txtJson = (TextView) findViewById(R.id.name);
btnHit.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
new JsonTask().execute("http://192.168.1.94/wamp/up.php");
}
});
}
private class JsonTask extends AsyncTask<String, String, String> {
protected void onPreExecute() {
super.onPreExecute();
pd = new ProgressDialog(MainActivity.this);
pd.setMessage("Please wait");
pd.setCancelable(false);
pd.show();
}
protected String doInBackground(String... params) {
HttpURLConnection connection = null;
BufferedReader reader = null;
try {
URL url = new URL(params[0]);
connection = (HttpURLConnection) url.openConnection();
connection.connect();
InputStream stream = connection.getInputStream();
reader = new BufferedReader(new InputStreamReader(stream));
StringBuffer buffer = new StringBuffer();
String line = "";
while ((line = reader.readLine()) != null) {
buffer.append(line + "\n");
Log.d("Response: ", "> " + line); //here u ll get whole response...... :-)
}
return buffer.toString();
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
if (connection != null) {
connection.disconnect();
}
try {
if (reader != null) {
reader.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
return null;
}
@Override
protected void onPostExecute(String result) {
super.onPostExecute(result);
if (pd.isShowing()) {
pd.dismiss();
}
txtJson.setText(result);
}
}
}
错误看起来像:
08-14 17:21:23.599 4201-4201/itawfik.com.myapplication E/SysUtils: ApplicationContext 在 ApplicationStatus 08-14 17:21:23.607 中为 null 4201-4201/itawfik.com.myapplication 电子邮件/libEGL: validate_display:255 错误 3008 (EGL_BAD_DISPLAY) 08-14 17:21:23.607 4201-4201/itawfik.com.myapplication 电子邮件/libEGL: validate_display:255 错误 3008 (EGL_BAD_DISPLAY)
[ 08-14 17:21:23.608 4201: 4201 D/ ]
HostConnection::get() 新主机连接已建立 0xb07743d0, tid 4201 08-14 17:21:23.799 4201-4201/itawfik.com.myapplication E/DataReductionProxySettingListener:由于以下原因,没有 DRP 密钥 异常:java.lang.ClassNotFoundException: com.android.webview.chromium.Drp
08-14 17:21:23.820 4201-4201/itawfik.com.myapplication E/AndroidRuntime:致命异常:main 进程:itawfik.com.myapplication,PID:4201 java.lang.RuntimeException:无法启动活动 ComponentInfo{itawfik.com.myapplication/itawfik.com.myapplication.MainActivity}: java.lang.NullPointerException:尝试调用虚拟方法“void” android.widget.Button.setOnClickListener(android.view.View$OnClickListener)' 在 null 对象引用上 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2416) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476) 在 android.app.ActivityThread.-wrap11(ActivityThread.java) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344) 在 android.os.Handler.dispatchMessage(Handler.java:102) 在android.os.Looper.loop(Looper.java:148) 在 android.app.ActivityThread.main(ActivityThread.java:5417) 在 java.lang.reflect.Method.invoke(本机方法) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 原因:java.lang.NullPointerException:尝试调用虚拟 方法 'void android.widget.Button.setOnClickListener(android.view.View$OnClickListener)' 在 null 对象引用上 在 itawfik.com.myapplication.MainActivity.onCreate(MainActivity.java:36) 在 android.app.Activity.performCreate(Activity.java:6237) 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1107) 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476) 在 android.app.ActivityThread.-wrap11(ActivityThread.java) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344) 在 android.os.Handler.dispatchMessage(Handler.java:102) 在android.os.Looper.loop(Looper.java:148) 在 android.app.ActivityThread.main(ActivityThread.java:5417) 在 java.lang.reflect.Method.invoke(本机方法) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
答:
我不确定它是否会解决您的问题,但在许多情况下,API 23 或更高版本中存在权限请求问题。
我在项目中也遇到了同样的问题,我通过使用波纹管程序解决了这个问题。
避免在上述 API 23 的初始屏幕中请求权限No DRP key due to exception:java.lang.ClassNotFoundException
例如:
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
permission = Settings.System.canWrite(this);
} else {
permission = ContextCompat.checkSelfPermission(this, Manifest.permission.WRITE_SETTINGS) == PackageManager.PERMISSION_GRANTED;
}
if (!permission) {
if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.M) {
Intent intent = new Intent(Settings.ACTION_MANAGE_WRITE_SETTINGS);
intent.setData(Uri.parse("package:" + getPackageName()));
startActivityForResult(intent, CODE_WRITE_SETTINGS_PERMISSION);
}
}
检查完以上权限后,在 中逐一检查剩余权限。onActivityResult
例如,
if (ActivityCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {
Log.v("Permission", Manifest.permission.WRITE_EXTERNAL_STORAGE+" Permission is revoked");
ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, CODE_WRITE_SETTINGS_PERMISSION);
return;
}
评论