最近很多小伙伴都在问java.lang.IllegalArgumentException:在方法名称中找到无效字符和CR或LF这两个问题,那么本篇文章就来给大家详细解答一下,同时本文还将给你拓展jav
最近很多小伙伴都在问java.lang.IllegalArgumentException:在方法名称中找到无效字符和CR或LF这两个问题,那么本篇文章就来给大家详细解答一下,同时本文还将给你拓展 java.lang.IllegalArgumentException、Base64:java.lang.IllegalArgumentException:非法字符、IllegalArgumentException:在HTTP协议中找到无效字符、IllegalArgumentException:无效的列等相关知识,下面开始了哦!
本文目录一览:- java.lang.IllegalArgumentException:在方法名称中找到无效字符(CR或LF)(java 找不到方法)
- java.lang.IllegalArgumentException
- Base64:java.lang.IllegalArgumentException:非法字符
- IllegalArgumentException:在HTTP协议中找到无效字符
- IllegalArgumentException:无效的列
java.lang.IllegalArgumentException:在方法名称中找到无效字符(CR或LF)(java 找不到方法)
如何解决java.lang.IllegalArgumentException:在方法名称中找到无效字符(CR或LF)?
此错误是由格式错误的HTTP请求引起的。在大多数情况下,此消息具有误导性,因为当您尝试通过https访问不安全的页面时,通常会发生此错误。Tomcat不知道传入的请求已加密,并且正在尝试将此请求解释为普通的,不安全的http请求。
Received [GET /index.html HTTP/1.1
Host: localhost:8080
Connection: keep-alive
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/46.0.2490.76 Mobile Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
Accept-Encoding: gzip, deflate, sdch
Accept-Language: pl,en-US;q=0.8,en;q=0.6
Cookie: Idea-xxxxx; JSESSIONID=3dxxxxx
]
Received [¹µHÄ;ß!P@<¿
#|vFBb-Ëiø/5
jÿ
hhttp/1.1uP
]
如您在第二个请求中看到的,存在未知字符而不是正确的HTTP方法名称(例如GET)
因此,如果您的服务器没有SSL配置,并且“在一两天内发生一次错误”,则可能有人试图通过https(可能是某种漫游器)访问您的网站。
最终,有人试图发送不安全但格式错误的纯HTTP请求(通过他自己的应用程序-机器人或其他自定义客户端)。
解决方法
我有一个运行在Tomcat8上的Spring MVC应用程序。一两天一次,我的日志文件中出现异常
15-Jun-2016 10:43:39.832 INFO [http-nio-8080-exec-50] org.apache.coyote.http11.AbstractHttp11Processor.process Error parsing HTTP request header
Note: further occurrences of HTTP header parsing errors will be logged at DEBUG level.
java.lang.IllegalArgumentException: Invalid character (CR or LF) found in method name
at org.apache.coyote.http11.AbstractNioInputBuffer.parseRequestLine(AbstractNioInputBuffer.java:228)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1009)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:672)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1502)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1458)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:745)
有人知道这可能是什么吗?
java.lang.IllegalArgumentException
问题描述:java.lang.IllegalArgumentException: Wrong state class, expecting View State but received class cn.etouch.ecalendar.waterfallview.StaggeredGridView$GridListSavedState instead. This usually happens when two views of different type have the same id in the same hierarchy. This view''s id is id/lv. Make sure other views do not use the same id.
问题出现情况分析:
android 5.0及以下版本如果出现这个问题,不要以为真的是id重复了。
我的项目情况是这样的在一个activity中有四个fagment ,F1,F2,F3,F4,在F2和F3的切换过程中,F4其实也已经初始化了,我在F4的布局中使用了自定义了一个ListView,它的id为lv.
之所以报错说id相同,大约是F4的上一次状态被保留下来了。
问题解决方案:
自定义的Listview的方法重写
@Override
protected void onRestoreInstanceState(Parcelable state) {
super.onRestoreInstanceState(state); }
修改为:
@Override
protected void onRestoreInstanceState(Parcelable state) {
try {
super.onRestoreInstanceState(state);
}catch (Exception e) {}
state=null;
}
Base64:java.lang.IllegalArgumentException:非法字符
我正在尝试在用户注册后发送确认电子邮件。我为此使用JavaMail库和Java 8 Base64 util类。
我以以下方式对用户电子邮件进行编码:
byte[] encodedEmail = Base64.getUrlEncoder().encode(user.getEmail().getBytes(StandardCharsets.UTF_8));
Multipart multipart = new MimeMultipart();
InternetHeaders headers = new InternetHeaders();
headers.addHeader("Content-type","text/html; charset=UTF-8");
String confirmLink = "Complete your registration by clicking on following"+ "\n<a href='" + confirmationURL + encodedEmail + "'>link</a>";
MimeBodyPart link = new MimeBodyPart(headers,confirmLink.getBytes("UTF-8"));
multipart.addBodyPart(link);
在哪里confirmationURL
:
private final static String confirmationURL = "http://localhost:8080/project/controller?command=confirmRegistration&ID=";
然后以这种方式在ConfirmRegistrationCommand中对此进行解码:
String encryptedEmail = request.getParameter("ID");
String decodedEmail = new String(Base64.getUrlDecoder().decode(encryptedEmail),StandardCharsets.UTF_8);
RepositoryFactory repositoryFactory = RepositoryFactory
.getFactoryByName(FactoryType.MYSQL_REPOSITORY_FACTORY);
UserRepository userRepository = repositoryFactory.getUserRepository();
User user = userRepository.find(decodedEmail);
if (user.getEmail().equals(decodedEmail)) {
user.setActiveStatus(true);
return Path.WELCOME_PAGE;
} else {
return Path.ERROR_PAGE;
}
当我尝试解码时:
http://localhost:8080/project/controller?command=confirmRegistration&ID=[B@6499375d
我正在java.lang.IllegalArgumentException: Illegal base64 character 5b
。
我尝试使用基本的编码/解码器(而不是URL编码),但没有成功。
解决了:
问题是下一个-在该行中:
String confirmLink = "Complete your registration by clicking on following"+ "\n<a href='" + confirmationURL + encodedEmail + "'>link</a>";
我在字节数组上调用toString,因此我应该执行以下操作:
String encodedEmail = new String(Base64.getEncoder().encode(
user.getEmail().getBytes(StandardCharsets.UTF_8)));
感谢 Jon Skeet 和 ByteHamster 。
IllegalArgumentException:在HTTP协议中找到无效字符
正如Steffen所述,HTTPS流量正在转发到您的应用程序。您的Cloud Front配置应该执行SSL终止,然后将请求转发到您的应用程序。
,配置CloudFront发行版的受支持HTTP版本
HTTP / 1.1,HTTP / 1.0
代替
HTTP / 2,HTTP / 1.1,HTTP / 1.0
解决了问题。
原始帖子中的异常仍然存在,但不再终止。
我认为提供Rest API的应用程序不支持HTTP 2,并且当从CloudFront重定向时,一些HTTP 2请求到达。然后以某种方式处理不受支持的http请求版本会导致一些致命错误,从而导致终止。如果我错了,请纠正我。
IllegalArgumentException:无效的列
这是logcat:
01-15 16:06:03.622: ERROR/AndroidRuntime(22300): Uncaught handler: thread main exiting due to uncaught exception
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.mohit.geo2do/com.mohit.geo2do.activities.TaskEdit}: java.lang.IllegalArgumentException: Invalid column due_date
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2496)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.app.ActivityThread.access$2200(ActivityThread.java:119)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.os.Handler.dispatchMessage(Handler.java:99)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.os.Looper.loop(Looper.java:123)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.app.ActivityThread.main(ActivityThread.java:4363)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at java.lang.reflect.Method.invokeNative(Native Method)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at java.lang.reflect.Method.invoke(Method.java:521)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:862)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:620)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at dalvik.system.NativeStart.main(Native Method)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): Caused by: java.lang.IllegalArgumentException: Invalid column due_date
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.database.sqlite.SQLiteQueryBuilder.computeProjection(SQLiteQueryBuilder.java:508)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.database.sqlite.SQLiteQueryBuilder.buildQuery(SQLiteQueryBuilder.java:356)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.database.sqlite.SQLiteQueryBuilder.query(SQLiteQueryBuilder.java:309)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.database.sqlite.SQLiteQueryBuilder.query(SQLiteQueryBuilder.java:266)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at com.mohit.geo2do.provider.TasksProvider.query(TasksProvider.java:174)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.content.ContentProvider$Transport.query(ContentProvider.java:130)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.content.ContentResolver.query(ContentResolver.java:202)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at com.mohit.geo2do.activities.TaskEdit.onCreate(TaskEdit.java:105)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
01-15 16:06:03.657: ERROR/AndroidRuntime(22300): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2459)
与之关联的行是:
private Cursor task;
private Uri uri;
private String[] PROJECTION {
Tasks._ID,Tasks.TITLE,Tasks.COMPLETED,Tasks.DUE_DATE,Tasks.IMPORTANCE,Tasks.NOTES
};
...
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.edit_task);
...
uri = getIntent().getData();
task = getContentResolver().query(uri,PROJECTION,null,null);
}
...
可能是什么问题呢?创建数据库就好了。您还需要查看其他代码吗?
更新:
我非常确定此列存在。我用这个查询数据库:
Cursor c = db.rawQuery("SELECT * FROM tasks LIMIT 1",null);
for (int i = 0; i < c.getColumnNames().length; i++) {
Log.v(TAG,c.getColumnNames()[i]);
}
在LogCat中:
01-15 16:52:07.857: VERBOSE/TasksProvider(24325): Creating database...
01-15 16:52:07.862: VERBOSE/TasksProvider(24325): _id
01-15 16:52:07.862: VERBOSE/TasksProvider(24325): title
01-15 16:52:07.862: VERBOSE/TasksProvider(24325): completed
01-15 16:52:07.862: VERBOSE/TasksProvider(24325): due_date
01-15 16:52:07.862: VERBOSE/TasksProvider(24325): notes
01-15 16:52:07.862: VERBOSE/TasksProvider(24325): importance
因此该列确实存在。
我们今天的关于java.lang.IllegalArgumentException:在方法名称中找到无效字符和CR或LF的分享已经告一段落,感谢您的关注,如果您想了解更多关于 java.lang.IllegalArgumentException、Base64:java.lang.IllegalArgumentException:非法字符、IllegalArgumentException:在HTTP协议中找到无效字符、IllegalArgumentException:无效的列的相关信息,请在本站查询。
本文标签: