乱码的原因???????????????????

本文介绍了在JSP开发中常见的中文乱码问题及其解决办法,包括页面显示、表单提交、数据库连接与显示等场景,并提供了具体的代码示例。

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

 
开发过程中,经常出现中文乱码的问题,可能一至困扰着您,我现在把我在JSP开发中遇到的中文乱码的问题及解决办法写出来供大家参考。 

  一、JSP页面显示乱码 

  下面的显示页面(display.jsp)就出现乱码: 

<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 

<body> 
<% 
out.print("JSP的中文处理"); 
%> 
</body> 
</html> 
  对不同的WEB服务器和不同的JDK版本,处理结果就不一样。原因:服务器使用的编码方式不同和浏览器对不同的字符显示结果不同而导致的。解决办法:在JSP页面中指定编码方式(gb2312),即在页面的第一行加上:
<%@ page contentType="text/html; charset=gb2312"%>,就可以消除乱码了。完整页面如下: 

<%@ page contentType="text/html; charset=gb2312"%> 
<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 
<body> 
<% 
out.print("JSP的中文处理"); 
%> 
</body> 
</html> 
  二、表单提交中文时出现乱码 

  下面是一个提交页面(submit.jsp),代码如下: 

<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 
<body> 
<form name="form1" method="post" action="process.jsp"> 
<div align="center"> 
<input type="text" name="name"> 
<input type="submit" name="Submit" value="Submit"> 
</div> 
</form> 
</body> 
</html> 
  下面是处理页面(process.jsp)代码: 

<%@ page contentType="text/html; charset=gb2312"%> 
<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 

<body> 
<%=request.getParameter("name")%> 
</body> 
</html> 
  如果submit.jsp提交英文字符能正确显示,如果提交中文时就会出现乱码。原因:浏览器默认使用UTF
-8编码方式来发送请求,而UTF-8和GB2312编码方式表示字符时不一样,这样就出现了不能识别字符。解决办法:通过request.seCharacterEncoding("gb2312")对请求进行统一编码,就实现了中文的正常显示。修改后的process.jsp代码如下: 

<%@ page contentType="text/html; charset=gb2312"%> 
<% 
request.seCharacterEncoding(
"gb2312"); 
%> 
<html> 
<head> 
<title>JSP的中文处理</title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 
<body> 
<%=request.getParameter("name")%> 
</body> 
</html> 
  三、数据库连接出现乱码 

  只要涉及中文的地方全部是乱码,解决办法:在数据库的数据库URL中加上useUnicode
=true&characterEncoding=GBK就OK了。 

  四、数据库的显示乱码 

  在mysql4.
1.0中,varchar类型,text类型就会出现中文乱码,对于varchar类型把它设为binary属性就可以解决中文问题,对于text类型就要用一个编码转换类来处理,实现如下: 

public class Convert 
/** 把ISO-8859-1码转换成GB2312 
*/
 
public static String ISOtoGB(String iso)
String gb; 
try
if(iso.equals(""|| iso == null)
return ""
}
 
else
iso 
= iso.trim(); 
gb 
= new String(iso.getBytes("ISO-8859-1"),"GB2312"); 
return gb; 
}
 
}
 
catch(Exception e)
System.err.print(
"编码转换错误:"+e.getMessage()); 
return ""
}
 
}
 
}

 

 

 

 

 

<%!

public String codeToString(String str)
{
String s
=str;

try
{
byte tempB[]=s.getBytes("ISO-8859-1");
s
=new String(tempB);
return s;
}

catch(Exception e)
{
return s;
}

}
 
%>


<%

int flag=0;
String auser_name
=codeToString((String)session.getAttribute("auser_name"));
String rank
=codeToString((String)session.getAttribute("rank"));



---------------------------------------------
you see
??
出现串口乱码通常与波特率不匹配、数据格式错误或硬件连接问题相关。以下是针对 **12MHz晶振** 的详细排查步骤和修正方案: --- ### **1. 波特率精确计算与验证** #### **问题原因** - 12MHz晶振下,若波特率寄存器值计算错误,会导致通信速率不一致。 - 公式: \[ \text{重载值} = 65536 - \frac{F_{\text{osc}}}{32 \times \text{Baud}} \] 对于12MHz、9600波特率: \[ \text{重载值} = 65536 - \frac{12,000,000}{32 \times 9600} \approx 65497 \quad (0xFFD9) \] #### **修正代码** ```c void UartInit() { T2L = 0xD9; // 低字节 T2H = 0xFF; // 高字节 AUXR |= 0x14; // 定时器2为1T模式(12T模式需改为0x04) AUXR |= 0x01; // 串口1使用定时器2 SCON = 0x50; // 8位数据,无校验 SBUF = 0; TI = 0; } ``` #### **关键点** - **1T模式**:STC15系列默认1T模式(`AUXR |= 0x14`),若误用12T模式会导致波特率错误。 - **验证方法**:用示波器测量TXD引脚的波特率(9600波特率对应每个比特位时长≈104μs)。 --- ### **2. 串口数据格式检查** #### **问题原因** - 串口助手与代码的数据格式(数据位、停止位、校验位)不一致。 #### **修正方案** - **代码配置**:`SCON = 0x50` 表示 **8位数据、无校验、1位停止位**(8N1)。 - **串口助手设置**:必须与代码完全一致(9600-8-N-1)。 --- ### **3. 硬件连接与电平匹配** #### **问题原因** - 单片机TXD与串口助手RXD未共地,或电平不兼容(如TTL与RS232混用)。 #### **修正方案** 1. **共地连接**:确保单片机GND与串口助手GND短接。 2. **电平转换**: - 若单片机输出TTL电平(0/5V),串口助手需支持TTL输入。 - 若使用RS232接口,需通过MAX232芯片转换电平。 --- ### **4. 代码优化与调试** #### **修正后的完整代码** ```c #include "stc15.h" #include <stdio.h> // 全局变量 unsigned int adc_value; float voltage; unsigned long freq_count; float frequency; char uart_buf[50]; // ADC初始化 void ADC_Init() { P1ASF = 0x01; // P1.0为模拟输入 ADC_CONTR = 0x80; // 开启ADC电源 } // ADC读取 unsigned int ADC_Read() { ADC_CONTR |= 0x08; // 启动转换 while (!(ADC_CONTR & 0x10)); // 等待完成 ADC_CONTR &= 0xEF; // 清除标志 return (ADC_RES << 2) | (ADC_RESL & 0x03); } // 频率测量初始化 void Freq_Init() { TMOD &= 0x0F; // 清除定时器1模式 TMOD |= 0x50; // 外部计数模式 TH1 = 0; TL1 = 0; // 清零计数器 TR1 = 1; // 启动计数 } // 串口初始化(12MHz晶振,9600波特率) void UartInit() { T2L = 0xD9; // 重载值低字节 T2H = 0xFF; // 重载值高字节 AUXR |= 0x14; // 定时器2为1T模式 AUXR |= 0x01; // 串口1使用定时器2 SCON = 0x50; // 8N1格式 SBUF = 0; TI = 0; } // 串口发送字符串 void UartSendString(char *s) { while (*s) { SBUF = *s++; while (!TI); // 等待发送完成 TI = 0; } } // 延时函数(约500ms) void Delay500ms() { unsigned int i, j; for (i = 0; i < 600; i++) for (j = 0; j < 420; j++); } // 主函数 void main() { ADC_Init(); Freq_Init(); UartInit(); while (1) { // 读取ADC并计算电压 adc_value = ADC_Read(); voltage = adc_value * 5.0 / 1024.0; // 测量频率(500ms闸门时间) TR1 = 0; freq_count = (TH1 << 8) | TL1; TH1 = 0; TL1 = 0; TR1 = 1; frequency = freq_count * 2.0; // 格式化输出 sprintf(uart_buf, "Voltage: %.2fV, Frequency: %.1fHz\r\n", voltage, frequency); UartSendString(uart_buf); Delay500ms(); } } ``` --- ### **5. 调试步骤** 1. **简化测试**: - 注释掉ADC和频率测量代码,仅发送固定字符串: ```c UartSendString("Test\r\n"); ``` - 若仍乱码,说明问题在串口配置或硬件。 2. **检查晶振频率**: - 用示波器测量XTAL1和XTAL2引脚的波形,确认频率为12MHz。 3. **更换串口工具**: - 尝试使用其他串口助手(如Putty、Tera Term)或逻辑分析仪。 4. **波特率容差**: - 某些串口助手对波特率误差敏感,尝试微调波特率(如921600或115200)测试。 --- ### **6. 常见问题总结** | 问题现象 | 可能原因 | 解决方案 | |----------------|-----------------------------------|-----------------------------------| | 全部乱码 | 波特率不匹配 | 重新计算波特率寄存器值 | | 部分字符乱码 | 数据格式不一致(如校验位) | 确保串口助手设置为8N1 | | 无输出 | 硬件连接错误或TXD引脚未配置 | 检查共地和电平转换 | | 输出不完整 | 缓冲区溢出或发送未等待完成 | 在`UartSendString`中等待`TI`标志 | ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值