Linux 소켓 왜곡 코드에 대한 해결 방법: 1. 터미널 명령 창을 엽니다. 2. iconv 명령을 사용하여 Linux 파일 문자 집합을 변환합니다. 변환 명령은 "iconv -f utf-8 -t gb2312 /server_test/입니다. 보고서/software_.txt > ;/server_test/reports/software_asserts.txt".
이 튜토리얼의 운영 환경: linux5.9.8 시스템, Dell G3 컴퓨터.
Linux 소켓이 깨졌을 경우 어떻게 해야 하나요?
linux, windows, 소켓 깨짐 문제
문제 설명:
linux에서 직접 작성한 ftp 클라이언트가 있고, windows에서 제공되는 소프트웨어를 사용하여 windows에 ftp 서버가 있습니다. 서버 중국어가 포함된 디렉터리를 생성하거나 중국어가 포함된 파일 이름을 생성할 때 중국어 이름이 깨집니다
문제 분석:
이것은 의심할 여지 없이 인코딩 문제로 인해 발생하는데 어떤 인코딩을 사용해야 하는지 확인하는 방법은 무엇입니까? Baidu는 나중에 우분투는 기본적으로 utf-8을 사용하고 Windows는 기본적으로 gbk를 사용한다는 사실을 발견했습니다. 따라서 중국어 경로가 포함된 콘텐츠가 전송될 때 gbk로 변환되는지 확인하세요
해결책:
utf8과 utf8 사이에서 변환 gbk :
Linux 파일 문자 집합 변환(utf8-gb2312)
첫 번째, 명령줄
LINUX에서 인코딩 변환을 수행할 때 iconv 명령을 사용하면 이를 수행할 수 있습니다. 한 인코딩에서 다른 인코딩으로 지정된 파일.
iconv 명령 사용법은 다음과 같습니다:
iconv [选项...] [文件...]
입/출력 형식 사양:
-f, --from-code=名称 原始文本编码 -t, --to-code=名称 输出编码
알려진 모든 문자 집합 나열 -l, --list
출력 제어:
-c 从输出中忽略无效的字符 -o, --output=FILE 输出文件 -s, --silent 关闭警告 --verbose 打印进度信息
예:
iconv -f utf-8 -t gb2312 /server_test/reports/software_.txt > /server_test/reports/software_asserts.txt
다음 필수 라이브러리 파일을 위해 임베디드 보드에 libiconv 라이브러리를 다운로드하세요
두 번째, 함수 적용
1. 헤더 파일
#include <iconv.h>
2.iconv_t iconv_open( const char *tocode, const char *fromcode);
이 함수는 어떤 두 인코딩이 변환되는지 설명합니다. tocode는 대상 인코딩이고 fromcode는 다음 두 함수에서 사용할 변환 핸들을 반환합니다.
(2) size_t iconv(iconv_t cd,char **inbuf,size_t *inbytesleft,char **outbuf,size_t *outbytesleft);
이 함수는 inbuf에서 문자를 읽고 변환한 후 outbuf로 출력합니다. inbytesleft가 사용됩니다. 변환되지 않은 문자 수를 기록하기 위해 outbytesleft를 사용하여 출력 버퍼의 남은 공간을 기록합니다.
(3) int iconv_close(iconv_t cd);
이 함수는 변환 핸들을 닫고 리소스를 해제하는 데 사용됩니다.
3.예: C 언어로 구현한 변환 샘플 프로그램
#include "stdio.h" #include "string.h" #include "iconv.h" #include "stdlib.h" static int charset_convert( const char *from_charset, const char *to_charset, char *in_buf, size_t in_left, char *out_buf, size_t out_left) { iconv_t icd = (iconv_t)-1; size_t sRet = -1; char *pIn = in_buf; char *pOut = out_buf; size_t outLen = out_left; if (NULL == from_charset || NULL == to_charset || NULL == in_buf || 0 >= in_left || NULL == out_buf || 0 >= out_left) { return -1; } icd = iconv_open(to_charset, from_charset); if ((iconv_t)-1 == icd) { return -1; } sRet = iconv(icd, &pIn, &in_left, &pOut, &out_left); if (( size_t )-1 == sRet) { iconv_close(icd); return -1; } out_buf[outLen - out_left] = 0; iconv_close(icd); return ( int )(outLen - out_left); } static int charset_convert_UTF8_TO_GB2312( char *in_buf, size_t in_left, char *out_buf, size_t out_left) { return charset_convert( "UTF-8" , "GB2312" , in_buf, in_left, out_buf, out_left); } static int charset_convert_GB2312_TO_UTF8( char *in_buf, size_t in_left, char *out_buf, size_t out_left) { return charset_convert( "GB2312-8" , "UTF-8" , in_buf, in_left, out_buf, out_left); } int main() { char *pIn = "hello 中国人" ; char *pOut = NULL; size_t outLen = 0; size_t inLen = 0; int iRet = -1; inLen = strlen (pIn); outLen = inLen * 3; pOut = ( char *) malloc ( sizeof ( char ) * outLen); if (NULL == pOut) { return -1; } memset (pOut, 0, sizeof ( char ) * outLen); iRet = charset_convert_UTF8_TO_GB2312(pIn, ( size_t )inLen, pOut, ( size_t )inLen); if (-1 == iRet) { return -1; } printf ( "out = %s;\touLen = %d\n" , pOut, iRet); free (pOut); pOut = NULL; return 0; }
이 구현은 크로스 플랫폼이 가능하며 개인적으로 더 좋다고 생각합니다~
ps: 제가 전에 만든 ftp 클라이언트는 Windows에 있었습니다. A측이 말했거든요. 거기에 이식하고 Windows로 전환했는데 위의 문제가 발생했습니다. 프로젝트에 나온 중국어 솔루션을 비교했지만 적어도 문제 해결 경험이 축적되었습니다 (중국어가 아닌 병음)
관련 추천: "
Linux 비디오 튜토리얼위 내용은 리눅스 소켓이 깨졌을 때 대처 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!