例外被抛出且未被接住问题

本文分析了使用Ajax时遇到的“例外被抛出且未被接住”异常原因,并给出了解决方案,主要涉及JSON字符串处理及DWR配置调整。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在开发在线聊天功能是,使用ajax时js抛出‘例外被抛出且未被接住’异常,网上找了找大多都是在用DWR时报的这个错误,
但是我没有使用DWR为什么报这个错呢!进过仔细的分析,终于发现这个异样的根源在于JSON,我在使用parseJSON时,
传入了非法的json字符串所以才报的这个错误。

以下是我转载的在DWR上的解决方案!

我在学习dwr时出现"例外被抛出且未被接住",后来在网上搜索找到了解决方法

 

在参照dwr的官方网站时,如果在后台出现如下的提示信息:A request has been denied as a potential CSRF attack

则,需要在web.xml中的如下配置修改一下

  1. <servlet>    
  2.     <servlet-name> dwr-invoker </servlet-name>    
  3.     <servlet-class> uk.ltd.getahead.dwr.DWRServlet</servlet-class>    
  4.     <init-param>    
  5.          <param-name> debug </param-name>    
  6.          <param-value> true </param-value>    
  7.     </init-param>    
  8. </servlet>    

 

改为:

  1. <servlet>    
  2.      <servlet-name>dwr-invoker</servlet-name>  
  3.      <servlet-class> uk.ltd.getahead.dwr.DWRServlet</servlet-class
  4.      <init-param>    
  5.          <param-name > debug </param-name >    
  6.          <param-value > true </param-value >    
  7.      </init-param>    
  8.      <init-param>    
  9.          <param-name> crossDomainSessionSecurity </param-name >    
  10.          <param-value> false </param-value >    
  11.      </init-param>  
  12.   </servlet>

 

即加入了跨域调用功能

此处servlet-class值为uk.ltd.getahead.dwr.DWRServlet (如果dwr版本是1.0版本的,则必须用这个class)

也可以是org.directwebremoting.servlet.DwrServlet

 如果确定java类的方法被调用了,但是页面还是出现了如下的报错: 例外被抛出且未被接住

此时,就不要忧郁了,赶紧换dwr.jar包,如下是我提供的能解决的这个问题的jar包,看附件

我使用这个附件里的jar包后完全正常了。

就换了dwr.jar包就行。

### Java 面试问题及答案 以下是针对具有 1 到 3 年经验的 Java 开发者的常见面试问题及其解答: #### 一、基础概念 1. **什么是面向对象编程?Java 中如何体现这些特性?** - 面向对象编程 (OOP) 是一种基于对象的程序设计范式,其核心理念包括封装、继承和多态。 封装通过将数据和行为绑定在一起并隐藏内部实现细节来增强安全性[^1]。例如,在 Java 中可以通过 `private` 访问修饰符保护字段,并提供公共方法供外部调用。 继承允许子类从父类中获取属性和方法,从而减少重复代码并提升扩展性。例如,使用关键字 `extends` 创建子类。 多态使得同一操作可以作用于不同的对象类型上,增强了灵活性和可维护性。 2. **解释装箱与拆箱的过程以及它们的作用。** - 装箱是指将基本数据类型自动转换为其对应的包装器类型的操作,而拆箱则是相反过程——将包装器类型转换回基本数据类型。这种机制简化了开发者的工作流程,减少了显式的类型转换需求[^2]。例如: ```java Integer a = Integer.valueOf(123); // 装箱 int b = a.intValue(); // 拆箱 ``` #### 二、集合框架 3. **ArrayList 和 LinkedList 的区别是什么?** - ArrayList 基于动态数组实现,随机访问性能较高(时间复杂度为 O(1)),但在中间位置插入或删除元素时效率较低(需移动大量元素)。LinkedList 使用双向链表结构存储元素,虽然随机访问较慢(时间复杂度为 O(n)),但插入和删除操作更高效,因为只需调整指针即可完成操作[^3]。 4. **HashMap 的工作原理是什么?** - HashMap 实现了一个键值对映射的数据结构,底层依赖哈希表实现快速存取功能。当插入一条记录时,会先计算该 key 对应的 hash 值以决定它应该被放置在哪一个桶里;如果发生冲突,则采用拉链法解决碰撞问题。此外,默认初始容量为 16,负载因子为 0.75,这意味着当实际大小超过此比例时会发生扩容操作[^4]。 #### 三、线程与并发 5. **Thread 类 vs Runnable 接口的区别在哪里?** - Thread 类本身实现了 Runnable 接口,因此可以直接覆盖 run 方法定义任务逻辑或者传递一个实现了 Runnable 接口的对象给它的构造函数。相比直接继承 Thread 来说,推荐优先考虑实现 Runnable 或 Callable 接口的方式,这样能够更好地遵循单一职责原则并更容易与其他组件集成[^5]。 6. **synchronized 关键字是如何工作的?** - synchronized 可用于同步方法或代码块,确保每次只有一个线程能进入临界区执行特定部分代码。对于实例方法而言,锁住的是当前对象(this),而对于静态方法来说则锁定整个 Class 对象。另外需要注意死锁风险以及性能开销等问题[^6]。 #### 四、异常处理 7. **try-catch-finally 结构中的 finally 是否总会被执行?** - 不论 try 块内的语句是否抛出捕获的异常还是正常结束返回,finally 子句几乎总是会被执行一次用来释放资源等清理动作。唯一例外情况是在 JVM 提前终止之前已经退出应用程序的情况下才不会运行 finally[]^7]^。 --- ### 示例代码片段 以下是一些可能涉及的实际编码场景: ```java // 展示 synchronized 的简单应用 public class Counter { private int count; public synchronized void increment() { this.count++; } public int getCount() { return this.count; } } ``` ```java // Lambda 表达式演示 List<String> names = Arrays.asList("Alice", "Bob", "Charlie"); names.forEach(name -> System.out.println(name)); ``` ---
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值