Qt:TXT文本读写的字符编码

Response返回我是这样写的,一开始写的toLocal8Bit(),在浏览器地址里面输入127.0.0.1:8080,能正常

显示中文,但web处理的时候却乱码了。然后我将toLocal8Bit()修改为toUtf8(),web就能正常处理了

复制代码
void HttpController::service(HttpRequest &request, HttpResponse &response) {

    QFile aFile("xxxxx.txt");

    if(!aFile.exists())
    {
        response.write("File does not exist",false);
    }

    if(!aFile.open(QIODevice::ReadOnly |QIODevice::Text))
    {
        response.write("Pattern exception",false);
    }

    QTextStream aStream(&aFile);
    QString text;
    text = aStream.readAll();
    //QByteArray byte= text.toLocal8Bit();
    QByteArray byte = text.toUtf8();
    response.write(byte,true);
    aFile.close();

}

toUtf8是输出UTF-8编码的字符集

toLatin1是相当与ASCii码不包含中文的遇到中文默认转换为ascii码0x3f也就是字符'?'

Local8bit是本地操作系统设置的字符集编码,一般为GB2312.

相关推荐
不剪发的Tony老师2 分钟前
pgmetrics:一款免费开源的PostgreSQL统计指标采集工具
数据库·postgresql
@insist1232 分钟前
数据库系统工程师-必知的系统开发知识
数据库·oracle·软考·数据库系统工程师·软件水平考试
星辰_mya4 分钟前
数据库运维与数据安全:备份恢复、日志分析与故障排查
运维·数据库·后端·面试·架构师
RisunJan4 分钟前
Linux命令-mysqladmin(MySQL服务器管理客户端)
linux·服务器·mysql
|华|8 分钟前
MySQL高可用详细解析
数据库·mysql
白露与泡影9 分钟前
InnoDB、PostgreSQL 与存算分离:刷脏保序的抉择
数据库·postgresql
无极低码11 分钟前
windows 程连接 Oracle 报 ORA-12541
数据库·windows·oracle
Meepo_haha13 分钟前
配置MyBatis-Plus打印执行的 SQL 语句到控制台或日志文件中
数据库·sql·mybatis
何中应18 分钟前
MindMap问题
运维·服务器·xmind
Carino_U26 分钟前
MySQL中Explain详解与索引最佳实践
数据库·mysql