aardio - wsock.tcp.simpleHttpServer 访问数据库例程

go 复制代码
import win.ui;
/*DSG{{*/
var winform = win.form(text="远程屏幕控制服务器";right=500;bottom=320)
winform.add(
edit={cls="edit";left=20;top=20;right=480;bottom=280;edge=1;multiline=1;readonly=1;vscroll=1;z=1}
)
/*}}*/
winform.show()
thread.invoke(function(winform){
    import win.ui;    
    import wsock.tcp.simpleHttpServer;
    import inet.adapter;
    // 获取本机局域网IP地址
    var localIp = wsock.getLocalIp();
    // 启动 HTTP 服务端
    var server = wsock.tcp.simpleHttpServer("0.0.0.0", 8081);
    // 在界面上显示服务器信息
    winform.edit.print(`
     📱 访问地址:
        本地访问: http://127.0.0.1:8081;
        局域网访问: http://` + localIp + `:8081
     📋 功能说明:
        🔴 演示远程sqlite表格的读取
    `)
    winform.show()
 
    // 在后台线程中运行服务器
    server.run(
        function(response, request){
            response.write(`
<!DOCTYPE html>
<html>
<head>
     <meta charset="UTF-8">
     <title>表格演示</title>
     <style>
         /* 表格整体样式 */
         table {
             width: 80%;
             margin: 30px auto;
             border-collapse: collapse; /* 合并边框 */
             font-family: "Microsoft YaHei", sans-serif;
             box-shadow: 0 2px 10px rgba(0,0,0,0.1); /* 轻微阴影 */
             border-radius: 8px;
             overflow: hidden;
         }

         /* 表头样式 */
         th {
             background-color: #409EFF;
             color: white;
             padding: 14px;
             text-align: center;
             font-weight: bold;
         }

         /* 单元格样式 */
         td {
             padding: 12px;
             text-align: center;
             border-bottom: 1px solid #eee;
         }

         /* 隔行变色 */
         tr:nth-child(even) {
             background-color: #f8f9fa;
         }

         /* 鼠标悬浮效果 */
         tr:hover {
             background-color: #e3f2fd;
             transition: 0.2s;
         }
     </style>
</head>
<body>
     <table>
         <tr>
             <th>标题</th>
             <th>长度</th>
             <th>年份</th>
             <th>描述</th>
         </tr>
`)
import sqlite
var db = sqlite("/test.db");
for title,length,year,starring in db.each("SELECT * FROM film") {
response.write(..string.format("<tr><td>%s</td><td>%s</td><td>%s</td><td>%s</td></tr>",title,length,year,starring));
}
db.close();
response.write(`</table>
</body>
</html>
`);
        }
    );
            
    // 窗口关闭时停止服务器
    winform.onClose = function(hwnd) {
        server.stop();
    }
    
    // 线程驻留
    while(true){
        thread.delay(1);
    }
    
},winform);

win.loopMessage();
相关推荐
翻斗包菜9 小时前
【MongoDB 从入门到实战:安装、配置、CRUD、权限、备份恢复全教程】
数据库·mongodb
weixin_424999369 小时前
如何用SQL按条件计算移动求和_结合CASE与窗口函数
jvm·数据库·python
21439659 小时前
持久化存储如何适配不同浏览器?解决隐私模式下存储失败的指南
jvm·数据库·python
justjinji9 小时前
c++怎么读取大端序设备的固件bin文件_字节反转与位移操作【详解】
jvm·数据库·python
m0_515098429 小时前
如何处理视图中的Definer_视图创建者权限变更对视图有效性的影响
jvm·数据库·python
2401_883600259 小时前
如何创建物化视图_CREATE MATERIALIZED VIEW基本语法与数据填充
jvm·数据库·python
xxjj998a9 小时前
MySQL无法连接到本地localhost的解决办法2024.11.8
数据库·mysql·adb
电商API_180079052479 小时前
京东商品详情接口返回数据说明API调用示例
数据库·性能优化·数据挖掘·数据分析·网络爬虫
Elivs.Xiang9 小时前
Redis - Docker环境下的持久化、主从复制、哨兵、集群、淘汰策略
数据库·redis·docker
绩隐金9 小时前
SQL Server 开发系列(第七期):触发器与约束——数据完整性的守护者
数据库