给你一个转换类public class CharsetProcess { public CharsetProcess() {
}
public static void main(String[] args) {
CharsetProcess charsetProcess1 = new CharsetProcess();
} public static String U2C(String s)
{
String str = s;
try
{
if ( str == null ) return str;
byte[] u = str.getBytes("iso-8859-1");
return new String(u,"GB2312");
}
catch(java.io.UnsupportedEncodingException e)
{
e.printStackTrace();
return str;
} }}
}
public static void main(String[] args) {
CharsetProcess charsetProcess1 = new CharsetProcess();
} public static String U2C(String s)
{
String str = s;
try
{
if ( str == null ) return str;
byte[] u = str.getBytes("iso-8859-1");
return new String(u,"GB2312");
}
catch(java.io.UnsupportedEncodingException e)
{
e.printStackTrace();
return str;
} }}
解决方案 »
- web安全方面 jsse jaas
- 关于多个Jpanel在Jframe里布局换行的问题,我贴出一段代码大家帮我看下,还有为什么Jtable的标题只显示一个,有图。
- 难倒高手,底层问题
- log4j怎么应用 高手帮忙看看我的代码有什么问题
- 请问一个sql更新语句
- 树形目录的表应该如何设计?
- 有谁知道如何在applet中使用ActiveX?
- 关于jTable中的Boolean类型的修改的问题
- 如何设置邮件信息体的类型 (Content-Type:) ?
- <***--请教高手:定义一个Vector和定义一个Object[],保存在其中的对象区别在哪?--***>
- 谁知道Sun ONE Studio 4 CE怎么用呀?
- 编译出错,看看你知不知道是什么错误
可以说一说原因,或是还有其他方法吗?我在自制的文本框中滚动时,每次光标必须动两格,否则又乱了
我的中文平台是zhcon
直接传,用两个辅助函数就行了
/*
* 关于下面两个辅助函数:以前我是直接使用JNI的API函数env->GetStringUTF()(好像是这个名字,我有点忘了)
和env->NewStringUTF()的。但是这两个函数对本地的GB2312(GBK)编码有问题,也就是
说中文会有问题。
因为Java是采用Unicode作为字符串编码的。
在JNI中只有四个函数GetStringUTF,NewStringUTF,GetStringChars,NewString,
前两个使用UTF8(可变字节),后两个是使用Unicode字符(16位双字节),
而本地的C程序时使用GB2312或者GBK编码的,这样就会产生编码错误,导致乱码。
所以采用WideCharToMultiByte和MultiByteToWideChar这两个函数把本地的
GB2312和GBK码换成Unicode16编码,再使用Jni函数来转化成Java String.
*////////////////////////////////////////////////////////////////////////////////
//辅助函数:char* jstringToWindows(JNIEnv* env,jstring jstr);
//功能:将Java的Unicode字符串转化成本地字符数组;
///////////////////////////////////////////////////////////////////////////////
char* jstringToWindows(JNIEnv* env,jstring jstr )
{
AFX_MANAGE_STATE(AfxGetStaticModuleState());
int length = env->GetStringLength(jstr );
const jchar* jcstr = env->GetStringChars(jstr, 0 );
char* rtn = (char*)malloc( length*2+1 );
int size = 0;
size = WideCharToMultiByte( CP_ACP, 0, (LPCWSTR)jcstr, length, rtn,
(length*2+1), NULL, NULL );
if( size <= 0 )
return NULL;
env->ReleaseStringChars(jstr, jcstr );
rtn[size] = 0;
return rtn;
}///////////////////////////////////////////////////////////////////////////////
//辅助函数:jstring windowsToJstring( JNIEnv* env, char* str )
//功能:将本地字符数组转化成Java的Unicode字符串;
///////////////////////////////////////////////////////////////////////////////
jstring windowsToJstring( JNIEnv* env, char* str )
{
AFX_MANAGE_STATE(AfxGetStaticModuleState());
jstring rtn = 0;
int slen = strlen(str);
wchar_t* buffer = 0;
if( slen == 0 )
rtn = env->NewStringUTF(str); //UTF ok since empty string
else
{
int length = MultiByteToWideChar( CP_ACP, 0, (LPCSTR)str, slen, NULL, 0 );
buffer = (wchar_t*)malloc( length*2 + 1 );
if( MultiByteToWideChar( CP_ACP, 0, (LPCSTR)str, slen, (LPWSTR)buffer, length ) >0 )
rtn = env->NewString( (jchar*)buffer, length );
}
if( buffer )
free( buffer );
return rtn;
}
如果在linux下,只要将其中的
unicode16->gb2312
和gb2312->unicode16的函数用linux的替换的就好了
这个问题主要是因为java native interface的API中
只提供了将java.String转成UTF8和Unicode16的方法
而UTF8编码一般是没有方法直接转成Gb2312的
所以都是将java.String -> U16 -> GB2312
如果还有什么不明白的,可以通过[email protected]
和我联系,如果你对这些编码的问题不了解,可以到
IBM developer Work去看,那里有很多的介绍
{
jstring rtn = 0;
jsize len = strlen(str); jclass clsstring = env->FindClass("java/lang/String"); //new encode string default "GBK"
jstring strencode = env->NewStringUTF(CURRENT_ENCODE);
jmethodID mid = env->GetMethodID(clsstring, "<init>", "([BLjava/lang/String;)V");
jbyteArray barr = env->NewByteArray(len); env->SetByteArrayRegion(barr,0,len,(jbyte*)str); //call new String(byte[] b,String encode)
rtn = (jstring)env->NewObject(clsstring,mid,barr,strencode); return rtn;
}char* jstringToChar(JNIEnv* env, jstring jstr)
{
char* rtn = NULL;
jclass clsstring = env->FindClass("java/lang/String"); //new encode string default "GBK"
jstring strencode = env->NewStringUTF(CURRENT_ENCODE);
jmethodID mid = env->GetMethodID(clsstring, "getBytes", "(Ljava/lang/String;)[B"); //call String.getBytes method to avoid incompatible migrating into solaris
jbyteArray barr= (jbyteArray)env->CallObjectMethod(jstr,mid,strencode); jsize alen = env->GetArrayLength(barr);
jbyte* ba = env->GetByteArrayElements(barr,JNI_FALSE); if(alen > 0)
{
rtn = (char*)malloc(alen+1); //new char[alen+1];
memcpy(rtn,ba,alen);
rtn[alen]=0;
}
env->ReleaseByteArrayElements(barr,ba,0); return rtn;
}