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

PHP会话技术

第十六章-PHP会话技术

PHP会话技术是构建动态、个性化Web应用的核心机制之一,它通过跟踪用户在网站上的连续操作状态,实现了网页间的数据持久化交互。无论是电商平台的购物车信息保存、社交媒体的用户登录状态维持,还是表单数据的跨页面传递,会话技术都发挥着不可替代的作用。在PHP中,开发者主要通过Cookie和Session两种方式实现会话管理:前者通过客户端存储键值数据完成轻量级状态跟踪,后者则借助服务器端存储与唯一会话ID的配合,为敏感信息提供更安全的解决方案。理解PHP会话技术的工作原理,不仅能优化用户体验,更是保障Web应用安全性的重要基石。

一,初步认识会话技术

初步认识会话技术:让网页“记住”用户的关键

当我们浏览网页时,每一次点击链接、提交表单或登录账户,本质上都是通过HTTP协议向服务器发送请求并接收响应。然而,HTTP协议本身是无状态的——服务器不会自动记录用户之前的操作,就像服务员每次接待顾客都当作陌生人一样。这种机制虽然保证了高效性,却无法满足现代Web应用对连续性交互的需求。例如,用户登录后如何在所有页面保持身份?电商购物车如何跨页面保存商品?这些问题都需要通过会话技术来解决。

会话技术的核心目标

会话技术的本质是在无状态的HTTP协议上实现有状态的交互。它通过某种方式让服务器或客户端能够“记住”用户在一段时间内的操作轨迹,从而提供连贯的个性化体验。常见的应用场景包括:

  • 用户身份保持:登录状态无需重复验证
  • 数据跨页传递:如多步骤表单的分页填写
  • 行为追踪:记录用户浏览路径或偏好设置

两种主流实现方式

PHP中主要依赖两种互补的会话技术,共同构建完整的用户跟踪体系:

  1. Cookie:客户端的记忆便签
    • 服务器通过HTTP响应头向浏览器发送键值对数据(如Set-Cookie: user=Alice;
    • 浏览器会将这些数据存储在本地,后续每次访问同一域时自动回传
    • 典型应用:记住登录状态、保存用户主题偏好等
  2. Session:服务器的保险箱
    • 在服务器端创建存储空间(如文件或数据库),每个用户拥有唯一会话ID
    • 通过Cookie或URL参数将会话ID与客户端绑定
    • 敏感数据(如购物车详情、临时验证码)安全存储在服务端
    • 典型应用:金融操作验证、多步骤流程数据暂存

技术选型的关键考量

  • 安全性:Cookie易被篡改,适合非敏感数据;Session数据存于服务端更安全
  • 存储限制:Cookie有4KB大小限制,Session理论上无上限
  • 生命周期:Cookie可设置长期留存,Session通常随浏览器关闭失效
  • 性能影响:高频访问的Session数据需考虑服务器存储压力

理解会话技术,就像掌握网站的“记忆魔法”——它让冷冰冰的协议具备了“人性化”的交互能力。无论是简单的页面偏好记忆,还是复杂的多步骤事务处理,会话管理都在背后默默支撑着现代Web的流畅体验。对于开发者而言,合理选择Cookie与Session的组合策略,既能保障功能实现,也是构建安全可靠系统的必修课。

二,Cookie技术使用

一、设置Cookie

使用setcookie()函数向客户端发送Cookie,必须在输出HTML内容前调用

// 基础设置(名称+值)
setcookie("username", "JohnDoe");// 完整参数设置(有效期7天,作用域全站,HTTPS传输,防JS访问)
setcookie("theme",          // Cookie名称"dark",           // 值time() + 604800,  // 过期时间戳(当前时间+7天)"/",              // 作用路径(全站)".example.com",   // 作用域名(包括子域名)true,             // 仅通过HTTPS传输true              // 禁止JavaScript访问(HttpOnly)
);

二、读取Cookie

通过$_COOKIE超全局数组获取已存储的值,务必先验证存在性

if(isset($_COOKIE["username"])) {$username = htmlspecialchars($_COOKIE["username"]); // 防XSSecho "欢迎回来, $username!";
} else {echo "首次访问用户";
}

三、删除Cookie

通过设置过期时间为过去时间触发浏览器删除:

// 删除时必须匹配原始设置路径/域名
setcookie("theme", "", time() - 3600, "/", ".example.com");

关键参数解析

参数说明示例值
过期时间UNIX时间戳格式,0表示会话Cookie(关闭浏览器失效)time() + 86400*30
作用路径指定哪些URL路径可访问Cookie,/表示全站/admin
作用域名允许子域名共享需设为.example.com形式.yourdomain.com
Securetrue时仅通过HTTPS传输需SSL环境启用
HttpOnlytrue时禁止JavaScript读取,防范XSS攻击建议敏感Cookie始终启用

安全使用准则

  1. 敏感数据避坑
    避免存储密码、身份令牌等敏感信息,必要时加密存储(如password_hash()

  2. 防御会话劫持
    为重要Cookie添加SameSite=Strict属性(PHP 7.3+):

    setcookie("session_id", $token, ['expires' => time() + 3600,'samesite' => 'Strict'
    ]);
    
  3. 容量限制
    单个Cookie不超过4KB,同一域名下通常最多允许50个Cookie


典型应用场景

  • 用户偏好记忆
    保存语言选择、主题颜色等非敏感设置

    setcookie("lang", "zh-CN", time() + 31536000); // 保存一年
    
  • 登录状态保持
    配合Session实现"记住我"功能(存储加密后的用户ID)

    $token = bin2hex(random_bytes(32)); // 生成随机令牌
    setcookie("remember_token", $token, time() + 2592000, "/", "", true, true);
    
  • 行为追踪
    记录用户首次访问时间、浏览历史(需符合隐私政策)

    if(!isset($_COOKIE["first_visit"])) {setcookie("first_visit", date("Y-m-d H:i:s"), time() + 31536000);
    }
    

调试技巧

  1. 浏览器检查
    按F12打开开发者工具 → Application → Cookies,实时查看存储状态

  2. PHP输出检测
    使用headers_list()函数检查是否成功发送Set-Cookie头

    print_r(headers_list()); // 查看所有响应头
    
  3. 过期时间转换
    使用date()函数验证时间戳是否正确:

    echo date("Y-m-d H:i:s", time() + 604800); // 显示7天后的日期
    

三,Cookie管理四要素

一、Cookie 生命周期管理

Cookie 的有效期由 expires 参数精确控制,时间管理是会话状态跟踪的核心。

  1. 临时会话 Cookie
    不设置 expires 或设为 0浏览器关闭即失效

    setcookie("session_temp", "data"); // 会话级 Cookie
    
  2. 持久化 Cookie
    使用明确的时间戳设置过期时间,支持长期存储:

    $expire = time() + 86400 * 30; // 30天后过期
    setcookie("remember_me", "user123", $expire);
    
  3. 时间计算技巧

    时间段计算公式示例值
    15分钟time() + 900适合短期验证码
    7天time() + 7*86400用户偏好设置
    1年time() + 365*86400长期登录令牌
  4. 强制过期删除
    通过设置过去时间戳触发浏览器删除:

    setcookie("old_cookie", "", time() - 3600, "/"); 
    

二、作用范围精准控制

通过 pathdomain 参数实现细粒度访问控制。

  1. 路径限制 (path)
    控制哪些 URL 路径可访问 Cookie:

    // 仅允许 /admin 路径访问
    setcookie("admin_token", "xyz", 0, "/admin/");
    
    • /:全站可访问(默认值)
    • /api/:仅 API 接口可用
  2. 域名作用域 (domain)

    • 精确域名:仅限指定域名

      setcookie("site_data", "val", 0, "/", "www.example.com");
      
    • 跨子域共享:使用 . 前缀

      setcookie("global_id", "123", 0, "/", ".example.com"); 
      // 支持 www.example.com、api.example.com 等子域
      
  3. 跨域限制

    • 默认遵循 同源策略,不同顶级域名无法共享
    • 需通过 CORS 或 JSONP 实现跨域传递(需服务端配合)

三、跨子域实战方案

以多子域系统(如 shop.example.comuser.example.com)为例:

  1. 统一认证系统

    // 认证服务器设置
    setcookie("auth_token", $token, ['expires' => time() + 3600,'path' => '/','domain' => '.example.com', // 关键点'secure' => true,'httponly' => true
    ]);
    
  2. 子域间数据同步

    // 在 user.example.com 读取 Cookie
    if(isset($_COOKIE["auth_token"])){// 所有子域均可获取该 Cookie
    }
    
  3. 安全注意事项

    • 仅限信任子域使用 .example.com
    • 敏感 Cookie 必须启用 Secure + HttpOnly

四、数组/对象数据存储

Cookie 本身仅支持字符串存储,结构化数据需编码处理。

  1. JSON 序列化方案

    // 存储数组
    $cart = ['product_id' => 1001, 'qty' => 3];
    setcookie("cart_data", json_encode($cart), time() + 3600);// 读取时解码
    $cart = json_decode($_COOKIE["cart_data"], true);
    
  2. Base64 安全编码
    防御特殊字符问题:

    $data = base64_encode(serialize($userPrefs));
    setcookie("prefs", $data);// 解码
    $userPrefs = unserialize(base64_decode($_COOKIE["prefs"]));
    
  3. 存储限制与优化

    数据类型推荐方案优势
    小型配置数据JSON 序列化易读易解析
    敏感复杂数据服务端存储 + Cookie ID避免数据泄露
    高频访问数据客户端缓存 + Cookie 标记减少服务端压力

五、浏览器行为差异

不同浏览器对 Cookie 的处理存在细微差别:

浏览器最大Cookie数/域名单Cookie大小限制SameSite 默认值
Chrome1804KBLax (2020+)
Firefox1504KBLax
Safari无明确限制4KBStrict

六、安全与性能平衡实践

  1. 敏感数据存储原则

    • 绝不存储:密码、信用卡号
    • 加密存储:用户 ID → "user_id" => encrypt(123, $secretKey)
    • 签名校验:存储值附带 HMAC 签名
  2. 性能优化技巧

    • 合并多个小 Cookie 为单个 JSON 对象
    • 静态资源域名禁用 Cookie(CDN 域名分离)
    // 图片服务器不使用 Cookie
    <img src="https://static.example.com/logo.png">
    

总结:Cookie 管理四要素

要素关键配置项典型值示例
生命周期expirestime() + 86400*30
作用路径path/api
跨域能力domain + samesite.example.com + Lax
数据安全secure + httponlytrue + true

四,PHP Cookie 高级特性

Cookie 不仅是简单的键值存储,其高级特性可解决复杂场景下的状态管理、安全防护与性能优化问题。以下深度解析 PHP 中 Cookie 的进阶用法,配合 安全策略实战场景,助您构建更健壮的 Web 应用。


一、安全增强特性

1. SameSite 防御 CSRF

PHP 7.3+ 支持直接设置 SameSite 属性,控制跨站请求是否携带 Cookie:

setcookie('auth_token', $token, ['expires' => time() + 3600,'samesite' => 'Strict',  // 严格模式:仅同站请求携带'secure' => true,        // 强制 HTTPS'httponly' => true       // 禁止 JS 访问
]);
  • Lax(默认):导航类请求(如链接跳转)携带 Cookie
  • Strict:仅同源请求携带,防御 CSRF 但可能破坏第三方登录
  • None:允许跨站携带(需同时设置 Secure
2. 前缀加固机制

通过 Cookie 前缀 声明 Cookie 的安全属性(Chrome 51+ 支持):

// 设置 __Host- 前缀的 Cookie(强制 Secure/Path=/ 且禁止指定 Domain)
setcookie('__Host-secure_id', 'value', ['expires' => time() + 86400,'secure' => true,'path' => '/'
]);
  • __Host-:全站强制安全 Cookie
  • __Secure-:需启用 Secure 标志的 Cookie
3. 签名防篡改

对 Cookie 值进行 HMAC 签名,防止客户端篡改:

$secret = 'your-secret-key';
$value = 'user123';
$signature = hash_hmac('sha256', $value, $secret);
setcookie('user', $value . '|' . $signature, ['httponly' => true]);// 验证时拆分并校验签名
list($storedValue, $storedSig) = explode('|', $_COOKIE['user'], 2);
if (hash_hmac('sha256', $storedValue, $secret) === $storedSig) {// 数据未被篡改
}

二、跨域与子域共享

1. 跨子域共享 Cookie

通过设置 Domain 参数实现多子域共享(如 shop.example.comblog.example.com):

setcookie('global_pref', 'dark', ['expires' => time() + 604800,'domain' => '.example.com', // 注意开头的点号'path' => '/'
]);
2. 跨域单点登录 (SSO)

结合 OAuth 2.0 与 CORS 实现跨域认证(需服务端协作):

// 认证服务器设置 Cookie 后,通过 iframe 或 JS 同步到其他域
header('Access-Control-Allow-Origin: https://client-app.com');
header('Access-Control-Allow-Credentials: true');
setcookie('sso_token', $token, ['domain' => '.sso-provider.net','secure' => true,'samesite' => 'None'
]);

三、性能优化策略

1. Cookie 压缩

对 JSON 等结构化数据进行编码压缩:

$data = ['theme' => 'dark', 'font' => '16px'];
$compressed = base64_encode(gzencode(json_encode($data)));
setcookie('user_prefs', $compressed);// 读取时解压
$data = json_decode(gzdecode(base64_decode($_COOKIE['user_prefs'])), true);
2. 分布式存储

大体积数据使用 Cookie 存储索引 ID,实际数据存于服务端:

// 存储到 Redis
$cartId = uniqid('cart_');
$redis->set($cartId, json_encode($cartData));
setcookie('cart_id', $cartId, ['httponly' => true]);// 读取时通过 ID 获取数据
$cartData = $redis->get($_COOKIE['cart_id']);
3. CDN 边缘 Cookie

与 CDN 服务协作缓存动态内容(需配置 Vary: Cookie 头):

header('Vary: Cookie'); // 告知 CDN 根据 Cookie 区分缓存版本
if (isset($_COOKIE['geo_region'])) {// 返回基于地区定制的内容
}

四、监控与调试

1. 浏览器端监控

通过 JavaScript 监听 Cookie 变化(需非 HttpOnly Cookie):

// 前端代码:监听指定 Cookie 变化
let lastCookie = document.cookie;
setInterval(() => {if (document.cookie !== lastCookie) {console.log('Cookie changed:', document.cookie);lastCookie = document.cookie;}
}, 1000);
2. 服务端日志分析

记录 Cookie 使用情况用于审计:

// 记录敏感 Cookie 的访问日志
if (isset($_COOKIE['auth_token'])) {error_log("Auth token used: " . $_SERVER['REMOTE_ADDR'] . ' at ' . date('Y-m-d H:i:s'));
}

五、前沿技术整合

1. Cookie 与 JWT 协同

混合使用 Cookie 存储 JWT 的刷新令牌:

// 生成 JWT 双令牌体系
$accessToken = generateJWT($user, '15m');  // 短期令牌存 Session
$refreshToken = generateJWT($user, '7d'); // 长期令牌存 Cookie
setcookie('refresh_token', $refreshToken, ['expires' => time() + 604800,'httponly' => true,'samesite' => 'Strict'
]);
2. WebAssembly 加密

使用 WASM 实现前端加密后再存储至 Cookie:

// 前端通过 WebAssembly 加密数据
// PHP 服务端解密
$encryptedData = $_COOKIE['secure_data'];
$iv = substr($encryptedData, 0, 16);
$cipherText = substr($encryptedData, 16);
$decrypted = openssl_decrypt($cipherText, 'aes-256-cbc', $key, 0, $iv);

六,PHP Session 技术


一、Session 核心原理

1. Session 的本质

Session 是服务器在内存或其他存储介质中为每个用户创建的一块存储空间,用于保存用户状态。


2. Session 标识:Session ID
  • 每次用户访问服务器时,服务器会生成一个唯一的 Session ID(通常是一个随机字符串)。
  • 这个 ID 会通过客户端浏览器返回并保存,通常放在 Cookie 中,也可以通过 URL 参数等方式传递。

3. 流程原理
[1] 客户端首次访问服务器↓
[2] 服务器生成 Session 对象(内存中保存一份)和唯一 Session ID↓
[3] Session ID 通过 Set-Cookie 返回给客户端↓
[4] 客户端下次请求时通过 Cookie 自动携带 Session ID↓
[5] 服务器接收 Session ID,查找对应的 Session 数据,恢复用户状态

4. Session 存储位置
  • 默认:服务器内存中(如 Python Flask、PHP 原生等)
  • 可扩展为:
    • Redis(分布式高可用)
    • 数据库(如 MySQL)
    • 文件系统

5. Session 生命周期
  • 默认是临时会话:浏览器关闭后 Cookie(及 Session ID)消失
  • 可设置有效期(如 30 分钟、7 天)
  • 服务端也会设置过期时间(maxInactiveInterval

二、Session 配置详解

在 PHP 开发中,Session 是保持用户状态最常见的方法之一,PHP 提供了丰富的配置项用于控制 Session 行为。通过 php.iniini_set() 调整核心参数:

配置项说明常见值 / 建议
session.save_handlerSession 存储方式files(默认),也可使用 redismemcached
session.save_path存储路径或连接信息(视 handler 而定)/tmptcp://127.0.0.1:6379
session.name存储在 Cookie 中的 Session ID 名称PHPSESSID(默认)
session.gc_maxlifetimeSession 生命周期(秒)1440(默认 24 分钟,可设为 1800+)
session.cookie_lifetimeCookie 有效期(秒),0 表示浏览器关闭即失效03600
session.cookie_pathCookie 有效路径/(默认)
session.cookie_domainCookie 有效域.example.com
session.cookie_secure是否仅在 HTTPS 中传输 Cookie1(建议开启)
session.cookie_httponly禁止 JS 读取 Session Cookie1(强烈建议开启)
session.use_cookies是否使用 Cookie 保存 Session ID1(默认)
session.use_only_cookies禁止通过 URL 传递 Session ID1(默认,强烈建议保留)
session.use_trans_sid是否自动通过 URL 传递 Session ID0(建议关闭)
session.sid_lengthSession ID 长度(PHP 7.1+)26(建议保持默认)
session.sid_bits_per_characterSession ID 中每个字符的比特数5/6

安全配置建议
session 配置优化
session.use_strict_mode = 1
session.use_only_cookies = 1
session.cookie_httponly = 1
session.cookie_secure = 1
session.cookie_samesite = Lax
session.gc_maxlifetime = 1800

PHP 脚本中设置(ini_set)
ini_set('session.gc_maxlifetime', 1800);
ini_set('session.cookie_httponly', 1);
ini_set('session.cookie_secure', 1);
ini_set('session.use_only_cookies', 1);
ini_set('session.cookie_samesite', 'Lax');
session_name('MYSESSIONID');
session_start();

使用 Redis 作为 Session 存储
  1. 安装 redis 扩展:

    pecl install redis
    
  2. 设置配置:

    session.save_handler = redis
    session.save_path = "tcp://127.0.0.1:6379"
    

session_start() 使用注意
  • 一定要在 echo 或 HTML 输出前调用
  • 调用一次即可自动读取和创建 Session
  • 修改 session 设置必须在 session_start() 之前完成

三、生命周期管理

Session 的有效期由 客户端 Cookie服务端数据 双重控制:

  1. 客户端过期
    通过 session.cookie_lifetime 控制会话 ID 在浏览器的留存时间:

    // 保持登录状态 7 天
    ini_set('session.cookie_lifetime', 86400 * 7);
    session_start();
    
  2. 服务端垃圾回收

    • session.gc_maxlifetime:数据过期时间(默认 24 分钟)
    • session.gc_probabilitysession.gc_divisor:垃圾回收触发概率(如 1/100)
    // 设置数据保留 2 小时,每次请求有 5% 概率触发 GC
    ini_set('session.gc_maxlifetime', 7200);
    ini_set('session.gc_probability', 5);
    ini_set('session.gc_divisor', 100);
    
  3. 手动销毁会话

    session_start();
    $_SESSION = [];                 // 清空数据
    session_destroy();              // 销毁会话
    setcookie(session_name(), '', time()-3600, '/'); // 强制客户端删除 Cookie
    

四、数据存储与序列化

$_SESSION 支持存储复杂数据结构,PHP 自动处理序列化/反序列化:

  1. 存储对象与资源

    // 存储对象(类必须已定义)
    class User { public $name; }
    $_SESSION['user'] = new User();
    $_SESSION['user']->name = 'Alice';// 资源类型无法序列化,需显式释放
    $file = fopen('log.txt', 'r');
    $_SESSION['file_handler'] = $file; // 触发警告!
    
  2. 自定义序列化处理器
    通过 session.serialize_handler 选择序列化方式:

    • php:PHP 内置格式(默认)
    • php_serialize:更安全的序列化方式
    ini_set('session.serialize_handler', 'php_serialize');
    session_start();
    $_SESSION['data'] = ['key' => 'value'];
    

五、安全防护策略

  1. 防御会话劫持

    • 绑定用户特征:校验 IP/User-Agent

      session_start();
      if ($_SESSION['user_agent'] !== $_SERVER['HTTP_USER_AGENT']) {session_regenerate_id(true); // 强制更换会话 IDsession_destroy();
      }
      
  2. 防止会话固定攻击

    session_start();
    if (!isset($_SESSION['initiated'])) {session_regenerate_id(true); // 登录成功后更换 ID$_SESSION['initiated'] = true;
    }
    
  3. 加密会话数据
    使用 session_set_save_handler 自定义存储加密:

    class EncryptedSessionHandler extends SessionHandler {private $key;public function __construct($key) {$this->key = $key;}public function read($id) {$data = parent::read($id);return openssl_decrypt($data, 'AES-256-CBC', $this->key);}public function write($id, $data) {$encrypted = openssl_encrypt($data, 'AES-256-CBC', $this->key);return parent::write($id, $encrypted);}
    }$handler = new EncryptedSessionHandler('your-secret-key');
    session_set_save_handler($handler, true);
    session_start();
    

六、高级存储方案

  1. 数据库存储会话(MySQL 示例)

    CREATE TABLE `sessions` (`id` varchar(128) NOT NULL,`data` text,`timestamp` int(11) NOT NULL,PRIMARY KEY (`id`)
    ) ENGINE=InnoDB;
    
    class DatabaseSessionHandler extends SessionHandler {private $pdo;public function open($savePath, $sessionName) {$this->pdo = new PDO('mysql:host=localhost;dbname=test', 'user', 'pass');return true;}public function read($id) {$stmt = $this->pdo->prepare("SELECT data FROM sessions WHERE id = ?");$stmt->execute([$id]);return $stmt->fetchColumn() ?: '';}public function write($id, $data) {$stmt = $this->pdo->prepare("REPLACE INTO sessions VALUES (?, ?, ?)");return $stmt->execute([$id, $data, time()]);}public function gc($maxLifetime) {$stmt = $this->pdo->prepare("DELETE FROM sessions WHERE timestamp < ?");return $stmt->execute([time() - $maxLifetime]);}
    }$handler = new DatabaseSessionHandler();
    session_set_save_handler($handler, true);
    session_start();
    
  2. Redis 加速会话

    ini_set('session.save_handler', 'redis');
    ini_set('session.save_path', 'tcp://127.0.0.1:6379?auth=secret');
    session_start(); // 自动连接 Redis
    

七、性能优化技巧

  1. 会话锁定机制
    PHP 默认使用阻塞式文件锁,高并发时可通过自定义处理器优化:

    class NonBlockingSessionHandler extends SessionHandler {public function read($id) {return parent::read($id);}public function write($id, $data) {// 禁用自动加锁return file_put_contents($this->getSessionFile($id), $data, LOCK_EX);}
    }
    
  2. 分布式会话共享
    使用 Redis 或 Memcached 实现多服务器共享:

    // Nginx 配置
    location ~ \.php$ {fastcgi_param PHP_VALUE "session.save_handler=redis\nsession.save_path=tcp://redis-cluster";
    }
    

八、最佳实践总结

场景推荐方案优势
小型站点默认文件存储 + HttpOnly Cookie简单易维护
高并发系统Redis 存储 + 非阻塞处理高吞吐低延迟
金融级安全数据库存储 + AES 加密防数据泄露
跨域单点登录共享 Session ID + 统一认证中心无缝跨系统跳转

相关文章:

  • 运用fmpeg写一个背英文单词的demo带翻译
  • UE5.3 C++ 房屋管理系统(一)
  • 在线caj转换word
  • 机器人运动控制技术简介
  • Rust 官方文档:人话版翻译指南
  • 动态规划-62.不同路径-力扣(LeetCode)
  • YOLO目标检测算法
  • 大模型——Trae IDE 指南:轻松配置自定义 AI 规则 (Trae Rules)
  • OR算法+ML模型混合推理框架架构演进
  • 智慧农业运维平台养殖—传感器管理监控设计—仙盟创梦IDE
  • 英伟达Blackwell架构重构未来:AI算力革命背后的技术逻辑与产业变革
  • Typora+PicGo+Gitee图床配置教程 自动图片上传
  • k8s监控方案实践(二):集成Alertmanager告警与钉钉Webhook通知
  • 公开模型一切,优于DeepSeek-R1,英伟达开源Llama-Nemotron家族
  • RT-THREAD RTC组件中Alarm功能驱动完善
  • MindSpore框架学习项目-ResNet药物分类-构建模型
  • 卷积神经网络实战(4)代码详解
  • 把Excel数据文件导入到Oracle数据库
  • k8s之statefulset
  • 低成本自动化改造的18个技术锚点深度解析
  • 湖南省职业病防治院通报3岁女童确诊“铊中毒”:去年病例,编辑误写为“近日”
  • 援藏博士张兴堂已任西藏农牧学院党委书记、副校长
  • 纽约大学朗格尼医学中心的转型带来哪些启示?
  • 两部门发布山洪灾害气象预警:北京西部、河北西部等局地山洪可能性较大
  • 85后清华博士黄佐财任湖北咸宁市咸安区委副书记、代区长
  • 老铺黄金拟配售募资近27亿港元,用于门店拓展扩建及补充流动资金等