将古老的ASP项目转换为PHP初探
ASP 是一种服务器端脚本语言,主要用于开发动态 Web 应用程序。ASP 可以在服务器上执行代码,并将结果返回给客户端浏览器,实现动态生成 Web 页面的功能。
ASP 代码通常包含在 <% %> 标记中,以下是一个简单的 ASP 程序示例:
<%
Response.Write "Hello, ASP!"
%>上面的代码将在浏览器中输出 "Hello, ASP!"。
ASP 中还提供了一些内置对象,如 Request、Response、Session 等,这些对象可以帮助我们与客户端交互,并处理用户请求和返回响应。以下是一个使用 Request 对象获取 GET 请求参数的示例:
<%
Dim name
name = Request.QueryString("name")
Response.Write "Hello, " & name & "!"
%>上面的代码将从 URL 中获取名为 name 的参数,并将其输出到页面中。
除了 ASP 之外,还有 ASP.NET 这个更加现代的版本,它使用 C# 或 VB.NET 等面向对象语言编写,可以使用更多的现代化技术和框架来开发 Web 应用程序。
转换概论
将 ASP 项目转换为 PHP 项目通常需要进行以下步骤,这也是项目代码转换的必经之路。
将 ASP 代码转换为 PHP 代码可以使用文本编辑器或 IDE 将 ASP 代码转换为 PHP 代码。由于 ASP 和 PHP 之间的语法和语义存在一些差异,因此需要仔细阅读代码并根据 PHP 的规范进行修改。
将 ASP 内置对象转换为 PHP 内置对象ASP 中提供了一些内置对象,如 Request、Response、Session 等,而 PHP 中的内置对象有所不同。在转换过程中,需要将 ASP 内置对象转换为 PHP 内置对象,以确保代码能够正常运行。
将数据库访问方式转换为 PHP 适用的方式在 ASP 项目中,可能使用了 ADO 和 ODBC 等方式访问数据库,而在 PHP 项目中,可以使用 PDO、mysqli 或者 mysql 等方式进行数据库访问。需要根据实际情况选择合适的方式,并将数据库访问代码进行相应修改。
调试和测试转换完成后,需要对 PHP 代码进行调试和测试,确保代码能够正常运行,并修复可能存在的问题。
需要注意的是,ASP 和 PHP 之间存在一些差异,因此在转换过程中需要耐心仔细,确保代码的正确性和可靠性。同时,如果 ASP 项目比较复杂,转换的难度可能会比较大,因此可以考虑使用现成的 ASP 转 PHP 工具进行转换。
基本代码转换
以下是一些常见的 ASP 代码示例及其对应的 PHP 代码:
输出文本
ASP 代码:
<% Response.Write "Hello, world!" %>PHP 代码:
<?php
echo "Hello, world!";
?>声明变量
ASP 代码:
<%
Dim strName
strName = "John"
%>PHP 代码:
<?php
$strName = "John";
?>读取请求参数
ASP 代码:
<%
strName = Request.QueryString("name")
%>PHP 代码:
<?php
$strName = $_GET["name"];
?>包含文件
ASP 代码:
<!--#include file="header.asp"-->PHP 代码:
<?php
include "header.php";
?>定义函数
ASP 代码:
<%
Function GetFullName(strFirstName, strLastName)GetFullName = strFirstName & " " & strLastName
End Function
%>PHP 代码:
<?php
function GetFullName($strFirstName, $strLastName) {return $strFirstName . " " . $strLastName;
}
?>控制结构
条件语句
ASP 代码:
<%
If intScore >= 90 ThenResponse.Write "A"
ElseIf intScore >= 80 ThenResponse.Write "B"
ElseIf intScore >= 70 ThenResponse.Write "C"
ElseIf intScore >= 60 ThenResponse.Write "D"
ElseResponse.Write "F"
End If
%>PHP 代码:
<?php
if ($intScore >= 90) {echo "A";
} elseif ($intScore >= 80) {echo "B";
} elseif ($intScore >= 70) {echo "C";
} elseif ($intScore >= 60) {echo "D";
} else {echo "F";
}
?>循环语句
ASP 代码:
<%
For i = 1 To 10Response.Write i & "<br>"
Next
%>PHP 代码:
<?php
for ($i = 1; $i <= 10; $i++) {echo $i . "<br>";
}
?>数组操作
定义数组
ASP 代码:
<%
Dim arrNames(3)
arrNames(0) = "Tom"
arrNames(1) = "Jerry"
arrNames(2) = "Mickey"
arrNames(3) = "Donald"
%>PHP 代码:
<?php
$arrNames = array("Tom", "Jerry", "Mickey", "Donald");
?>访问数组元素
ASP 代码:
<%
Dim arrNames(3)
arrNames(0) = "Tom"
arrNames(1) = "Jerry"
arrNames(2) = "Mickey"
arrNames(3) = "Donald"Response.Write arrNames(1) ' 输出 "Jerry"
%>PHP 代码:
<?php
$arrNames = array("Tom", "Jerry", "Mickey", "Donald");echo $arrNames[1]; // 输出 "Jerry"
?>数组操作
ASP 中的数组操作:
myarray = Array("apple", "banana", "cherry")
Response.Write myarray(1) '输出 "banana"对应的 PHP 代码:
$myarray = array("apple", "banana", "cherry");
echo $myarray[1]; // 输出 "banana"字符串操作
查询字符串参数
ASP 代码:
<%
strName = Request.QueryString("name")
strAge = Request.QueryString("age")Response.Write "Your name is " & strName & " and your age is " & strAge
%>PHP 代码:
<?php
$strName = $_GET["name"];
$strAge = $_GET["age"];echo "Your name is " . $strName . " and your age is " . $strAge;
?>字符串操作
ASP 中的字符串操作:
mystring = "hello world"
Response.Write Left(mystring, 5) '输出 "hello"对应的 PHP 代码:
$mystring = "hello world";
echo substr($mystring, 0, 5); // 输出 "hello"数据库操作
连接数据库
ASP 代码:
<%
Set conn = Server.CreateObject("ADODB.Connection")
conn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\mydb.mdb;"Set rs = Server.CreateObject("ADODB.Recordset")
rs.Open "SELECT * FROM customers", connDo Until rs.EOFResponse.Write rs("name") & "<br>"rs.MoveNext
Looprs.Close
Set rs = Nothing
conn.Close
Set conn = Nothing
%>PHP 代码:
<?php
$conn = new COM("ADODB.Connection");
$conn->Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\mydb.mdb;");$rs = new COM("ADODB.Recordset");
$rs->Open("SELECT * FROM customers", $conn);while (!$rs->EOF) {echo $rs->Fields("name") . "<br>";$rs->MoveNext();
}$rs->Close();
$conn->Close();
?>数据库查询
ASP 代码:
<%
Set conn = Server.CreateObject("ADODB.Connection")
conn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\mydata.mdb"
Set rs = conn.Execute("SELECT * FROM Customers")
While Not rs.EOFResponse.Write rs("CustomerName") & "<br>"rs.MoveNext
Wend
rs.Close
Set rs = Nothing
conn.Close
Set conn = Nothing
%>PHP 代码:
<?php
$conn = new mysqli("localhost", "username", "password", "mydata");
$result = $conn->query("SELECT * FROM Customers");
while ($row = $result->fetch_assoc()) {echo $row["CustomerName"] . "<br>";
}
$result->free();
$conn->close();
?>表单处理
ASP 中的表单处理:
<%
If Request.Form("username") = "admin" And Request.Form("password") = "123456" ThenResponse.Redirect "success.asp"
ElseResponse.Write "Username or password is incorrect"
End If
%>对应的 PHP 代码:
<?php
if ($_POST["username"] == "admin" && $_POST["password"] == "123456") {header("Location: success.php");exit;
} else {echo "Username or password is incorrect";
}
?>以下是更多的 ASP 代码和相应的 PHP 代码示例:
日期和时间
ASP 中的日期和时间操作:
mydate = Now()
Response.Write Year(mydate) '输出当前年份对应的 PHP 代码:
$mydate = date("Y-m-d H:i:s");
echo date("Y", strtotime($mydate)); // 输出当前年份文件操作
ASP 中的文件操作:
Set fs = Server.CreateObject("Scripting.FileSystemObject")
Set f = fs.OpenTextFile("myfile.txt", ForReading)
mytext = f.ReadAll
f.Close对应的 PHP 代码:
$myfile = fopen("myfile.txt", "r");
$mytext = fread($myfile, filesize("myfile.txt"));
fclose($myfile);异常处理
ASP 中的异常处理:
On Error Resume Next
'执行可能抛出异常的代码
If Err.Number <> 0 ThenResponse.Write "Error: " & Err.Description
End If
On Error GoTo 0对应的 PHP 代码:
try {// 执行可能抛出异常的代码
} catch (Exception $e) {echo "Error: " . $e->getMessage();
}Session 和 Cookie
ASP 中的 Session 和 Cookie 操作:
Session("myvar") = "myvalue"
Response.Cookies("mycookie") = "myvalue"对应的 PHP 代码:
session_start();
$_SESSION["myvar"] = "myvalue";
setcookie("mycookie", "myvalue", time() + (86400 * 30), "/");邮件发送
ASP 中的邮件发送:
Set mail = Server.CreateObject("CDO.Message")
mail.From = "sender@example.com"
mail.To = "recipient@example.com"
mail.Subject = "Test email"
mail.TextBody = "This is a test email."
mail.Configuration.Fields.Item("http://schemas.microsoft.com/cdo/configuration/smtpserver") = "smtp.example.com"
mail.Configuration.Fields.Item("http://schemas.microsoft.com/cdo/configuration/smtpserverport") = 25
mail.Configuration.Fields.Update
mail.Send对应的 PHP 代码:
$to = "recipient@example.com";
$subject = "Test email";
$message = "This is a test email.";
$headers = "From: sender@example.com" . "\r\n" ."Reply-To: sender@example.com" . "\r\n" ."X-Mailer: PHP/" . phpversion();
mail($to, $subject, $message, $headers);以上是一些常见的 ASP 代码和相应的 PHP 代码示例,但需要注意的是,不同的编程语言具有不同的特性和语法,因此在进行 ASP 转 PHP 时,需要仔细检查代码并根据具体情况进行调整。
内置对象的转换
将 ASP 内置对象转换为 PHP 内置对象需要注意 ASP 和 PHP 语言的差异,下面是一些常见的 ASP 内置对象及其 PHP 对应的内置对象:
Request 对象
ASP 中的 Request 对象用于获取客户端提交的 HTTP 请求数据,PHP 中可以使用 $_REQUEST 超全局变量来实现同样的功能。
在 ASP 中:
<%
Dim myValue
myValue = Request.Form("myInput")
%>在PHP中:
<?php
$myValue = $_REQUEST["myInput"];
?>Response 对象
ASP 中的 Response 对象用于向客户端发送 HTTP 响应数据,PHP 中可以使用 echo 和 print 语句来输出数据。
在 ASP 中:
<%
Response.Write "Hello World!"
%>在PHP中:
<?php
echo "Hello World!";
?>Server 对象
ASP 中的 Server 对象提供了一些常用的方法和属性,如 Server.MapPath、Server.Execute 等,PHP 中可以使用相应的函数来实现同样的功能。
在 ASP 中:
<%
Dim myPath
myPath = Server.MapPath("myFile.txt")
Set myFile = Server.CreateObject("Scripting.FileSystemObject").OpenTextFile(myPath, 1)
myContent = myFile.ReadAll
myFile.Close
%>在PHP中:
<?php
$myPath = $_SERVER["DOCUMENT_ROOT"] . "/myFile.txt";
$myFile = fopen($myPath, "r");
$myContent = fread($myFile, filesize($myPath));
fclose($myFile);
?>Session 对象
ASP 中的 Session 对象用于在不同页面之间保存和共享数据,PHP 中可以使用 $_SESSION 超全局变量来实现同样的功能。
在 ASP 中:
<%
Session("myVar") = "myValue"
myValue = Session("myVar")
%>在PHP中:
<?php
session_start();
$_SESSION["myVar"] = "myValue";
$myValue = $_SESSION["myVar"];
?>Application 对象
ASP 中的 Application 对象用于在整个应用程序范围内保存和共享数据,PHP 中可以使用全局变量或者文件缓存等方式来实现同样的功能。
在 ASP 中:
<%
Application.Lock
Application("myVar") = "myValue"
Application.Unlock
myValue = Application("myVar")
%>在PHP中:
<?php
$myPath = $_SERVER["DOCUMENT_ROOT"] . "/myFile.txt";
$myFile = fopen($myPath, "r");
$myContent = fread($myFile, filesize($myPath));
fclose($myFile);
?>由于ASP 和 PHP 的语法和语义有很大的不同,转换过程中需要根据具体情况进行调整和改写,以确保程序的正确性和可靠性。
数据库语句的转换
将 ASP 的 ADO 和 ODBC 访问数据库转换为 PHP 的 PDO、mysqli 或者 mysql 访问数据库,需要进行以下的语法转换:
连接数据库
ASP 的 ADO 连接数据库的语法:
set conn = Server.CreateObject("ADODB.Connection")
conn.Open "Provider=SQLOLEDB;Data Source=myServerAddress;Initial Catalog=myDataBase;User Id=myUsername;Password=myPassword;"PHP 的 PDO 连接数据库的语法:
$servername = "myServerAddress";
$username = "myUsername";
$password = "myPassword";
$dbname = "myDataBase";try {$conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);// 设置 PDO 错误模式为异常$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);echo "连接成功";
} catch(PDOException $e) {echo "连接失败: " . $e->getMessage();
}查询数据
ASP 的 ADO 查询数据的语法:
set rs = Server.CreateObject("ADODB.Recordset")
rs.CursorLocation = 3
rs.Open "SELECT * FROM myTable", conn, 1, 3PHP 的 PDO 查询数据的语法:
$sql = "SELECT * FROM myTable";
foreach ($conn->query($sql) as $row) {print $row['id'] . "\t";print $row['name'] . "\t";print $row['age'] . "\n";
}插入数据
ASP 的 ADO 插入数据的语法:
sql = "INSERT INTO myTable (name, age) VALUES ('John Doe', 30)"
conn.Execute sqlPHP 的 PDO 插入数据的语法:
$sql = "INSERT INTO myTable (name, age) VALUES ('John Doe', 30)";
$conn->exec($sql);
echo "新记录插入成功";更新数据
ASP 的 ADO 更新数据的语法:
sql = "UPDATE myTable SET name='Jane Doe' WHERE id=1"
conn.Execute sqlPHP 的 PDO 更新数据的语法:
$sql = "UPDATE myTable SET name='Jane Doe' WHERE id=1";
$conn->exec($sql);
echo $stmt->rowCount() . " 条记录被更新";删除数据
ASP 的 ADO 删除数据的语法:
sql = "DELETE FROM myTable WHERE id=1"
conn.Execute sqlPHP 的 PDO 删除数据的语法:
$sql = "DELETE FROM myTable WHERE id=1";
$conn->exec($sql);
echo $stmt->rowCount() . " 条记录被删除";代码的调试
在 ASP 转 PHP 后,如果代码存在错误或需要调试,可以使用以下方法进行调试:
使用 PHP 的错误报告机制。在 PHP 代码中加入以下代码可以开启错误报告:
error_reporting(E_ALL);
ini_set('display_errors', 1);这样可以将所有错误信息输出到屏幕上,帮助开发者定位错误。
在 PHP 代码中加入调试信息。可以在代码中使用 echo 或者 var_dump 等函数输出变量或对象的值,帮助开发者了解代码的运行状态。
使用 PHP 调试工具。PHPStorm、Xdebug、Zend Debugger 等都是常用的 PHP 调试工具,可以帮助开发者在 IDE 中进行代码调试。
使用日志工具。可以在代码中加入日志输出功能,将运行日志输出到日志文件中,帮助开发者查看代码运行状态。
综上,调试 ASP 转 PHP 后的代码,需要多加注意错误报告、日志输出、调试信息等方面,多使用工具和技巧帮助开发者定位问题,提高调试效率。
相关文章:
将古老的ASP项目转换为PHP初探
ASP 是一种服务器端脚本语言,主要用于开发动态 Web 应用程序。ASP 可以在服务器上执行代码,并将结果返回给客户端浏览器,实现动态生成 Web 页面的功能。ASP 代码通常包含在 <% %> 标记中,以下是一个简单的 ASP 程序示例&…...
数据结构复习(七)模板类封装实现不带头结点的单链表
一、代码 二、总结 一、代码 #include<iostream> using namespace std;template<class T> struct ListNode {T _data;ListNode* next;ListNode(const T& data T()){_data data;next nullptr;}~ListNode(){next nullptr;} };template<class T> class…...
IDEA插件 RestfulTool插件——Restful服务开发辅助工具集
IDEA插件 RestfulTool插件——Restful服务开发辅助工具集 目录IDEA插件 RestfulTool插件——Restful服务开发辅助工具集1.插件介绍2.安装方式3.使用方法1.插件介绍 RestfulTool插件。一套 Restful 服务开发辅助工具集: 提供了一个 Services tree 的显示窗口 双击 …...
2023年全国最新会计专业技术资格精选真题及答案1
百分百题库提供会计专业技术资格考试试题、会计考试预测题、会计专业技术资格考试真题、会计证考试题库等,提供在线做题刷题,在线模拟考试,助你考试轻松过关。 11.下列各项中,影响企业利润表“利润总额”项目的是(&…...
Linux 配置RAID组
目录 配置RAID(软件RAID) 创建RAID组 RAID中出现坏盘如何操作 RAID 添加热备盘 删除RAID组 RAID所解决的问题 提升硬盘的I/O吞吐率 提高硬盘的读写能力 提高硬盘的安全性 进行备份 减少硬盘成本 RAID级别 存储RAID——RAID级别_静下心来敲木鱼的博…...
【2021/推荐/社交网络】Socially-Aware Self-Supervised Tri-Training for Recommendation
部分公式、图表和排版等显示可能异常,可在个人公众号(码农的科研笔记)进行全文免费阅读。 【2021/推荐/社交网络】Socially-Aware Self-Supervised Tri-Training for Recommendation 原文:https://dl.acm.org/doi/10.1145/3447548.3467340 源码:[伯乐 SEPT]、https://git…...
Django搭建个人博客Blog-Day06
展示所有文章Django提供的分页功能说明import os os.environ.setdefault(DJANGO_SETTINGS_MODULE, blog.settings.dev) import django django.setup() # 这个时候才有django的环境 所以导入django中的模块必须写在这句话的后面才有效 from articles.models import Articles #…...
DQL 多表查询
1、多表关系 一对多(多对一) 案例: 部门 与 员工的关系 关系: 一个部门对应多个员工,一个员工对应一个部门 实现: 在从表的一方建立外键,指向主表一方的主键 多对多 案例: 学生 与 课程的关系 关系: 一个学生可以选修多门课程&am…...
BUUCTF Reverse xor
题目:BUUCTF Reverse xor 一些犯傻后学到了新东西的记录 查壳,没壳,IDA打开 main函数很好理解,输入一个长度为33的字符串,1-32位与前一位异或后与global相等,则判定flag正确 找global 在strings window直…...
vite和esbuild/roolup的优缺点
esbuild 优点 基于go语言,go是纯机器码不使用 AST,优化了构建流程多线程并行 缺点 esbuild 没有提供 AST 的操作能力。所以一些通过 AST 处理代码的 babel-plugin 没有很好的方法过渡到 esbuild 中(比如babel-plugin-import)。…...
32-Golang中的map
Golang中的map基本介绍基本语法map声明的举例map使用的方式map的增删改查操作map的增加和更新map的删除map的查找map的遍历map切片基本介绍map排序map的使用细节基本介绍 map是key-value数据结构,又称为字段或者关联数组。类似其它编程语言的集合,在编程…...
LeetCode-384-打乱数组
1、列表随机 为了能够初始化数组,我们使用nums保存当前的数组,利用orignal保存初始化数组。为了实现等可能随机打乱,考虑到随机数本质上是基于随机数种子的伪随机,我们采用如下的方式实现等可能随机:我们将所有元素压…...
九龙证券|重大利好!期货公司打新再“解绑”:可直接参与首发网下配售!
时隔近7年,期货公司及其财物办理子公司参加首发证券网下询价和配售事务再次“解绑”。 2月17日,为适应全面实行股票发行注册制变革需求,中国证券业协会(以下简称中证协)发布《初次公开发行证券网下出资者办理规矩》&am…...
信号完整性设计规则之串扰最小化
本文内容从《信号完整性与电源完整性分析》整理而来,加入了自己的理解,如有错误,欢迎批评指正。 1. 对于微带线和带状线,保持相邻信号路径的间距至少为线宽的2倍。 减小串扰的一种方式就是增大线间距,使线间距等于线…...
Windows Ubuntu双系统 设置时间同步方式
文章目录0 前言1 系统时间机制1.1 Windows时间机制1.2 Ubuntu时间机制2 设置Ubuntu的时间机制3 参考0 前言 在安装windows与ubuntu的双系统之后,会发现两个系统的时间不一致,如果使用了Ubuntu之后,再使用windows就会发现时间变早。原因是两个…...
【python】英雄联盟电竞观赛引擎 掉落提示 CapsuleFarmerEvolved 「Webhook」「钉钉」
介绍 本项目链接 Github本项目链接 Gitee本项目链接 最近在github上发现一个可以用来自动帮你挂英雄联盟(除国服)电竞引擎(可以开出头像和表情)的项目,CapsuleFarmerEvolved,github原项目链接简单来说就是本来是通过看比赛获取奖励的,它帮助你进行观看. 对这个活动有兴趣的话…...
加油站会员管理小程序实战开发教程11
我们已经用了10篇的篇幅讲解了首页的功能,首页主要是用来展示信息的。那么接下来就要进入我们的功能页面了,会员管理一个比较重要的功能是充值的功能。 要想实现充值功能,首先需要办一张会员卡,那什么时候办理会员卡呢?需要先注册成为会员,然后进行开卡的动作。这里要注…...
Python量化入门:投资的风险有哪些?
在金融资产中,风险是指获得收益的不确定性,通常以实际收益与期望收益的偏离来表示。 影响资产收益的因素有很多,而且不同资产面对的风险也不尽相同,在详细介绍风险度量之前,我们有必要了解一下风险的来源。 资产风险的来源 1. 市场风险 市场风险就是我们常说的系统…...
AV1编码标准整体概述
本专栏预计将从如下几方面详细介绍AV1 (1)从AV1的发展历史,AV1与MPEG、AVS系列的异同。 (2)AV1标准支持的传统编码工具及引入的机器学习工具 (3)开源的AV1编码器及解码器原理详解 (4)AV1的生态 一、AV1产生背景 2010年,谷歌收购了一家叫On2 Technologies的公司。那时VP8…...
基于springboot+vue的药物咨询平台
基于springbootvue的药物咨询平台 ✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取项目下载方式🍅 一、项目背景介绍&…...
uniapp 对接腾讯云IM群组成员管理(增删改查)
UniApp 实战:腾讯云IM群组成员管理(增删改查) 一、前言 在社交类App开发中,群组成员管理是核心功能之一。本文将基于UniApp框架,结合腾讯云IM SDK,详细讲解如何实现群组成员的增删改查全流程。 权限校验…...
多云管理“拦路虎”:深入解析网络互联、身份同步与成本可视化的技术复杂度
一、引言:多云环境的技术复杂性本质 企业采用多云策略已从技术选型升维至生存刚需。当业务系统分散部署在多个云平台时,基础设施的技术债呈现指数级积累。网络连接、身份认证、成本管理这三大核心挑战相互嵌套:跨云网络构建数据…...
(十)学生端搭建
本次旨在将之前的已完成的部分功能进行拼装到学生端,同时完善学生端的构建。本次工作主要包括: 1.学生端整体界面布局 2.模拟考场与部分个人画像流程的串联 3.整体学生端逻辑 一、学生端 在主界面可以选择自己的用户角色 选择学生则进入学生登录界面…...
Spring Boot 实现流式响应(兼容 2.7.x)
在实际开发中,我们可能会遇到一些流式数据处理的场景,比如接收来自上游接口的 Server-Sent Events(SSE) 或 流式 JSON 内容,并将其原样中转给前端页面或客户端。这种情况下,传统的 RestTemplate 缓存机制会…...
在rocky linux 9.5上在线安装 docker
前面是指南,后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...
CMake基础:构建流程详解
目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...
c++ 面试题(1)-----深度优先搜索(DFS)实现
操作系统:ubuntu22.04 IDE:Visual Studio Code 编程语言:C11 题目描述 地上有一个 m 行 n 列的方格,从坐标 [0,0] 起始。一个机器人可以从某一格移动到上下左右四个格子,但不能进入行坐标和列坐标的数位之和大于 k 的格子。 例…...
ESP32 I2S音频总线学习笔记(四): INMP441采集音频并实时播放
简介 前面两期文章我们介绍了I2S的读取和写入,一个是通过INMP441麦克风模块采集音频,一个是通过PCM5102A模块播放音频,那如果我们将两者结合起来,将麦克风采集到的音频通过PCM5102A播放,是不是就可以做一个扩音器了呢…...
基于Java Swing的电子通讯录设计与实现:附系统托盘功能代码详解
JAVASQL电子通讯录带系统托盘 一、系统概述 本电子通讯录系统采用Java Swing开发桌面应用,结合SQLite数据库实现联系人管理功能,并集成系统托盘功能提升用户体验。系统支持联系人的增删改查、分组管理、搜索过滤等功能,同时可以最小化到系统…...
scikit-learn机器学习
# 同时添加如下代码, 这样每次环境(kernel)启动的时候只要运行下方代码即可: # Also add the following code, # so that every time the environment (kernel) starts, # just run the following code: import sys sys.path.append(/home/aistudio/external-libraries)机…...
