当前位置: 首页 > news >正文

仓颉编程语言入门 -- Socket 编程与HTTP 编程概述

仓颉的 Socket 编程概述

在网络通信的广阔天地中,仓颉的Socket编程如同一座桥梁,连接着不同的计算设备,实现了基于传输层协议的数据传输。无论是追求稳定可靠的TCP,还是偏好轻量级、无连接的UDP,Socket都扮演着不可或缺的角色。

可靠传输:TCP

在TCP的舞台上,客户端与服务端精心编排着一场连接与通信的舞蹈。服务端首先优雅地登台,创建并绑定一个监听特定端口的Socket,然后静待有缘人的连接请求。客户端则怀揣着明确的目标地址与端口,创建Socket并发起连接请求。一旦双方牵手成功,这场舞蹈便正式拉开序幕,数据报文的收发变得如丝般顺滑。

TCP服务端示例

// 假设我们有一个伪代码环境  
let serverPort = 8080  function startTcpServer() {  // 创建并绑定服务端Socket  let serverSocket = createTcpServerSocket(serverPort)  serverSocket.bind()  // 等待并接受客户端连接  let clientSocket = serverSocket.accept()  // 读取并处理数据  let buffer = allocateBuffer(10)  let bytesRead = clientSocket.read(buffer)  print("Server received: ", buffer.slice(0, bytesRead))  // 后续可以继续与客户端通信或关闭连接  
}  // 调用函数启动服务器  
startTcpServer()

TCP客户端示例

let serverIp = "127.0.0.1"  
let serverPort = 8080  function connectToTcpServer() {  // 创建客户端Socket并连接到服务器  let clientSocket = createTcpSocket(serverIp, serverPort)  clientSocket.connect()  // 发送数据  let dataToSend = [1, 2, 3]  clientSocket.write(dataToSend)  // 关闭连接(在实际应用中,根据需求决定是否立即关闭)  // clientSocket.close()  
}  // 调用函数连接到服务器  
connectToTcpServer()
不可靠传输:UDP

相比之下,UDP的通信方式则显得更为随性不羁。无需建立连接,数据报文的发送与接收都更加直接且高效,但代价是牺牲了可靠性。在UDP的世界里,服务端与客户端的角色不再那么泾渭分明,每个套接字都是独立的舞者,自由地发送与接收来自四面八方的数据。

UDP服务端示例

let serverPort = 8080  function startUdpServer() {  // 创建并绑定UDP Socket  let serverSocket = createUdpSocket(serverPort)  serverSocket.bind()  // 接收数据  let buffer = allocateBuffer(3)  let (senderAddress, bytesRead) = serverSocket.receiveFrom(buffer)  print("Received from ", senderAddress, ": ", buffer.slice(0, bytesRead))  
}  // 异步启动UDP服务器  
asyncStart(startUdpServer)

UDP客户端示例

let serverIp = "127.0.0.1"  
let serverPort = 8080  function sendUdpData() {  // 创建UDP Socket并绑定(有时可以省略绑定步骤)  let clientSocket = createUdpSocket()  // 客户端通常不需要显式绑定,除非有特定需求  // clientSocket.bind(anyLocalPort)  // 发送数据到服务器  let dataToSend = [1, 2, 3]  clientSocket.sendTo(serverIp, serverPort, dataToSend)  // 无需关闭连接,UDP是无连接的  
}  // 调用函数发送数据  
sendUdpData()

HTTP 编程

HTTP 协议,作为互联网上的通用语言,通过请求与响应的交互模式,在客户端与服务端之间架起了一座数据传输的桥梁。每当用户通过浏览器或其他客户端软件访问网络资源时,都会发送一个HTTP请求给服务器,而服务器则根据请求的内容返回相应的HTTP响应。这些请求和响应都遵循着固定的格式,包括报文头和报文体,确保了数据传输的准确性和完整性。

在HTTP的请求类型中,GET和POST是最为常用的两种。GET请求主要用于从服务器请求数据,其特点是在请求行中直接包含要访问的资源路径,且请求体中不包含数据(尽管实际上GET请求也可能带有查询字符串,但这通常不被视为请求体的一部分)。而POST请求则用于向服务器提交数据,这些数据被放置在请求体中,并通过一个空行与请求头分隔开。

仓颉框架,作为一款强大的网络开发工具,支持HTTP 1.0、1.1及2.0等多个协议版本,让开发者能够轻松构建高性能的客户端和服务端应用。通过利用仓颉提供的HttpRequestBuilder和HttpResponseBuilder类,开发者可以灵活地构造符合RFC 9110、9112、9113、9218、7541等标准规范的HTTP请求和响应报文。

下面是一个使用仓颉框架进行客户端和服务端编程的示例。在这个示例中,服务端将监听本地8080端口,并注册了一个处理"/hello"路径的请求处理器。当客户端发送GET请求到"/hello"时,服务端将返回"Hello Cangjie!"作为响应体。

服务端代码:

import 'net.http.dart';  
import 'std.time.dart';  
import 'std.sync.dart';  void startServer() {  // 1. 初始化并配置Server实例  var server = ServerBuilder()  .address("127.0.0.1")  .port(8080)  .build();  // 2. 注册路由处理函数  server.router.addRoute("/hello", (HttpContext httpContext) {  httpContext.response.body = "Hello Cangjie!";  });  // 3. 启动服务器监听  server.listen();  
}  void main() {  spawn(startServer);  sleep(Duration.seconds(1));  startClient(); // 假设startClient在后续调用,实际中可能需要其他方式触发  
}  // 注意:这里假设了startClient函数已经定义,并且会在服务端启动后适当时间被调用  
// 实际情况下,你可能需要在另一个脚本或程序中启动客户端,或者使用某种形式的同步/异步机制
http://www.lryc.cn/news/428128.html

相关文章:

  • Oracle基本SQL操作-用户角色权限管理
  • Qt-信号和槽(8)
  • 80.游戏的分辨率修改思路与分析
  • MaxKB(二):Ubuntu24.04搭建maxkb开发环境
  • c#实现数据导出为PDF的方式
  • 【联想电脑】:使用拓展坞后转接HDMI,无法识别显示屏
  • Verilog刷题笔记53
  • GoFly快速开发后台框架-后端接口请求返回403提示码就跨域问题/请求端域名拦截问题
  • 设备实时数据采集:开启制造业智能化、自动化的新篇章
  • 【python与java的区别-03(集合、字典)】
  • Java继承
  • Kafka集群搭建的两种方式
  • 两种变量初始化方法的区别
  • 群晖把硬盘共享给win10(虚拟机或物理机)的两种办法
  • Java-Web面试题汇总
  • 数字化技术分别有哪些,数字化技术特点和优势是什么?
  • 微服务CI/CD实践(一)环境准备及虚拟机创建
  • 【SpringBoot】优化慢启动应用的用户体验
  • String str=“i“ 与 String str=new String (“i“) 一样吗?
  • 【数据结构】二叉树链式结构的实现
  • 如何有效找到目标客户群体?
  • 机器学习-混淆矩阵
  • 数据结构----栈
  • STL六大组件
  • 【机器学习】CNN的数学基础
  • 最小路径和[中等]
  • 【题库】——数组 小鱼比可爱
  • 基于飞腾平台的Hbase的安装配置
  • 【springboot】springboot接口参数全局解密,解决request内容修改后如何重新设置回去的问题
  • yml基本语法