实现QQ一键登录功能的ASP技术指南

本文还有配套的精品资源,点击获取 menu-r.4af5f7ec.gif

简介:QQ一键登录ASP版是一个网页登录解决方案,允许用户利用QQ账号快速登录网站。该方案包括多个文件,每个文件都执行特定功能:qqconnect.asp用于调用QQ API与服务器交互;user.asp处理登录后的用户信息;redirect.asp负责用户授权完成后的重定向;common.asp是公共函数库;index.html展示登录按钮;qq_login.png为登录按钮的图像资源。该功能涉及ASP编程、OAuth2.0授权、QQ开放平台API调用、HTTP通信、数据库操作和状态管理等技术点。 QQ一键登录asp版

1. QQ一键登录ASP实现

在当今数字化时代,用户登录系统越来越倾向于便捷与安全并重。QQ一键登录为用户提供了一种快速且安全的登录方式,使得用户无需记住复杂的密码,即可通过QQ账号登录其他网站或应用。ASP(Active Server Pages)作为一种服务器端脚本环境,可以用来创建动态交互式网站。本章将详细讲解如何使用ASP技术实现QQ一键登录功能,涵盖从基础的登录逻辑到与QQ服务器的交互细节。

在本章中,我们将首先介绍ASP实现QQ一键登录的基本概念和步骤。随后,我们会深入探讨如何通过 qqconnect.asp 文件与QQ服务器进行通信,并解析服务器返回的数据。我们还会讨论 user.asp 文件如何处理用户信息,以及如何通过 redirect.asp 实现OAuth2.0授权重定向机制。

1.1 QQ一键登录的实现原理

实现QQ一键登录的核心是OAuth2.0协议,这是一个安全的授权框架,允许应用请求有限的访问权限,而不是获取用户的用户名和密码。在ASP环境下,我们可以通过以下步骤实现该功能:

  1. 用户点击登录按钮。
  2. 应用通过 qqconnect.asp 文件向QQ开放平台发起授权请求。
  3. QQ开放平台验证请求合法性后,引导用户进行登录并授权。
  4. 授权成功后,QQ开放平台将授权码发送回应用的 redirect.asp 页面。
  5. 应用使用授权码获取用户的访问令牌。
  6. 应用通过访问令牌请求用户信息,并进行相应的用户信息处理。

这个过程不仅简化了用户的登录步骤,还提高了应用的安全性,因为它避免了存储和传输敏感的用户凭证。

1.2 实现过程中的关键组件

  • qqconnect.asp : 与QQ服务器进行交互的ASP文件,负责发送HTTP请求并接收响应。
  • user.asp : 用于处理获取到的用户信息,包括信息的验证、存储和更新。
  • redirect.asp : 在OAuth2.0授权流程中负责重定向,接收授权码,并处理后续的令牌获取逻辑。

这些组件协同工作,实现了从用户授权到信息处理的完整流程,为用户提供无缝且安全的登录体验。接下来的章节将详细介绍这些组件的设计和实现细节。

2. ASP实现细节与交互

2.1 qqconnect.asp与QQ服务器交互

2.1.1 与QQ服务器通信的HTTP请求

在ASP中实现与QQ服务器的通信,首先需要构建一个HTTP请求,通过这个请求来完成用户身份的验证和授权。HTTP请求是客户端与服务器进行交互的一种方式,通常包括请求头(Headers)、请求方法(如GET、POST)、请求参数(Parameters)等信息。在ASP中,可以使用WinINet或者XMLHTTP等组件来发送HTTP请求。

例如,使用XMLHTTP发送HTTP GET请求的ASP代码如下:

<%
Dim objXMLHTTP, strURL, strParams, strResponse
strURL = "***"

Set objXMLHTTP = Server.CreateObject("MSXML2.XMLHTTP")
objXMLHTTP.Open "GET", strURL, False
objXMLHTTP.setRequestHeader "User-Agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1)"
objXMLHTTP.send

If objXMLHTTP.Status = 200 Then
    strResponse = objXMLHTTP.responseText
End If

' 释放对象
objXMLHTTP.Abort
Set objXMLHTTP = Nothing
%>

在上述代码中,构建了一个请求URL,指定了请求的服务器端点、应用ID、重定向URI、状态码、作用域等参数。使用 XMLHTTP 对象的 Open send 方法来发送请求,并通过 responseText 属性接收响应内容。

2.1.2 解析QQ服务器响应数据

从QQ服务器获取到的响应数据通常为HTML页面、JSON格式或XML格式的字符串。若响应数据为JSON格式,需要对其进行解析以获取有用信息。在ASP中,可以使用JSON解析器如 ADODB.Stream 来实现。

下面是一个解析JSON响应数据的示例:

<%
' 假设strResponse变量包含了从QQ服务器接收到的JSON格式响应字符串
Dim objJSON, strData
strData = '{"access_token":"...","expires_in":7200,"refresh_token":"...","openid":"...","scope":"GET_USER_INFO","token_type":"Bearer"}'

Set objJSON = New JSONobject
objJSON.parse strData

' 解析后的数据
Dim access_token, openid
access_token = objJSON("access_token")
openid = objJSON("openid")

' 输出获取的信息
Response.Write "Access Token: " & access_token & "<br>"
Response.Write "OpenID: " & openid & "<br>"
%>

在上述代码中,首先创建了一个 JSONobject 对象,并使用 parse 方法解析包含在 strData 变量中的JSON字符串。然后通过指定的键(如 "access_token" "openid" )来提取和输出所需的数据。

2.2 user.asp用户信息处理

2.2.1 用户信息的获取与验证

在用户授权后,需要获取用户的相关信息,以便于后续的业务处理。用户信息通常通过QQ开放平台提供的API接口获取,并且需要验证这些信息的真实性。可以通过请求用户信息API,得到用户的基本信息,如用户ID、昵称等。

下面是一个获取用户信息的示例代码:

<%
Dim objXMLHTTP, strURL, strResponse
strURL = "***" & Session("AccessToken") & "&oauth_consumer_key=" & Session("AppId") & "&openid=" & Session("OpenId")

Set objXMLHTTP = Server.CreateObject("MSXML2.XMLHTTP")
objXMLHTTP.Open "GET", strURL, False
objXMLHTTP.setRequestHeader "User-Agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1)"
objXMLHTTP.send

If objXMLHTTP.Status = 200 Then
    strResponse = objXMLHTTP.responseText
    ' 将响应内容转化为JSON格式进行解析
    ' 这里假设已经存在解析JSON的方法,故直接解析字符串
    Dim objJSON, user_info
    Set objJSON = New JSONobject
    objJSON.parse strResponse
    user_info = objJSON("user_info")
    Response.Write user_info
End If

' 释放对象
objXMLHTTP.Abort
Set objXMLHTTP = Nothing
%>

在这个示例中,构建了请求QQ用户信息API的URL,并将用户授权时获取的 access_token AppId OpenId 作为参数传递。通过 XMLHTTP 发送请求,并解析返回的JSON数据获取用户信息。

2.2.2 用户信息的存储与更新

获取用户信息之后,接下来需要进行的是存储和更新操作。这通常涉及到将用户信息存储到数据库中,以便于应用程序可以后续查询和使用。在存储用户信息时,需要考虑数据的安全性、完整性和隐私保护。

下面是一个存储用户信息的示例代码:

<%
' 假设已经解析得到用户信息存储在变量user_info中
Dim objConn, objRS, strSQL, strUserInfo
strUserInfo = Replace(user_info, """", """") ' 转义双引号,以防止SQL注入攻击

' 连接数据库
Set objConn = CreateObject("ADODB.Connection")
objConn.Open "Provider=sqloledb;Data Source=YOUR_SERVER_NAME;Initial Catalog=YOUR_DATABASE_NAME;User ID=YOUR_USERNAME;Password=YOUR_PASSWORD;"

' 准备SQL语句
strSQL = "INSERT INTO Users (UserId, UserInfo) VALUES ('" & Session("OpenId") & "', '" & strUserInfo & "') ON DUPLICATE KEY UPDATE UserInfo = '" & strUserInfo & "'"

' 执行SQL语句
Set objRS = objConn.Execute(strSQL)

' 清理资源
objRS.Close
Set objRS = Nothing
objConn.Close
Set objConn = Nothing
%>

在上述代码中,首先对用户信息中的双引号进行了转义处理以防止SQL注入攻击。然后创建了数据库连接,并准备了插入或更新用户信息的SQL语句。通过执行该SQL语句,实现了用户信息的存储。 ON DUPLICATE KEY UPDATE 子句用于处理当用户已存在时更新其信息。

2.3 redirect.asp OAuth2.0授权重定向

2.3.1 构建重定向URL的逻辑

在OAuth2.0授权流程中,当用户同意授权后,QQ服务器会将用户重定向到在应用中设置的 redirect_uri 。在此过程中,QQ服务器会附加一个授权码(Authorization Code)作为URL的查询参数。应用服务器需要解析这个URL,并使用授权码来交换用户的访问令牌(Access Token)。

在ASP中,构建重定向URL的逻辑可能会是这样的:

<%
Dim strRedirectUri, strAuthorizeCode, strAccessTokenUri
strRedirectUri = "***"
strAuthorizeCode = Request.QueryString("code")

' 拼接获取Access Token的URL
strAccessTokenUri = "***" & strAuthorizeCode & "&redirect_uri=" & Server.URLEncode(strRedirectUri)

' 执行获取Access Token的过程(参考2.1.2节的代码示例)

' 这里可加入错误处理逻辑,如处理HTTP请求失败或解析响应出错的情况
%>

在上述代码中,首先从查询字符串中获取授权码,然后构建了获取访问令牌的URL,并执行了请求。 Server.URLEncode 方法用于对重定向URI进行URL编码,以确保URL中特殊字符被正确处理。

2.3.2 处理重定向后的授权码

获取到授权码后,需要对其进行处理,通过它来向QQ服务器请求访问令牌。这个步骤是在redirect.asp中完成的,通常会在用户同意授权后立即执行。

下面是处理授权码并获取访问令牌的示例代码:

<%
' 假设strAccessTokenUri变量包含了获取访问令牌的URL
Dim objXMLHTTP, strResponse
Set objXMLHTTP = Server.CreateObject("MSXML2.XMLHTTP")
objXMLHTTP.Open "GET", strAccessTokenUri, False
objXMLHTTP.setRequestHeader "User-Agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1)"
objXMLHTTP.send

If objXMLHTTP.Status = 200 Then
    strResponse = objXMLHTTP.responseText
    ' 输出获取的响应内容,以便于查看是否正确获取到Access Token
    Response.Write strResponse
    ' 进一步解析响应字符串,获取Access Token
    ' 这里假设已存在解析响应字符串的方法,故直接输出Access Token
    Dim access_token
    access_token = ... ' 解析获取到的Access Token
    Response.Write "Access Token: " & access_token
End If

' 释放对象
objXMLHTTP.Abort
Set objXMLHTTP = Nothing
%>

在上述代码中,使用 XMLHTTP 组件发送了一个HTTP GET请求,该请求的URL包含了授权码和其他必要参数。服务器响应后,将响应内容输出,并假定进一步的解析工作可以获取到访问令牌。需要注意的是,在实际应用中,需要将响应内容解析为可用的数据格式,例如JSON或URL编码的查询参数格式。

3. ASP编程技术与基础架构

ASP(Active Server Pages)是微软公司开发的一种服务器端脚本环境,它使得开发者能够使用VBScript或JavaScript等脚本语言来创建动态网页。本章节深入探讨了ASP编程技术的多个方面,以及它在构建基础架构时所扮演的关键角色。

3.1 common.asp公共函数库

3.1.1 设计公共函数库的目的

在ASP开发中,公共函数库是一种常见的代码复用技术。通过将通用的代码片段封装到函数中,并在一个单独的文件里进行集中管理,可以显著提高开发效率,并保持代码的整洁性。具体来说,设计公共函数库的目的有以下几点:

  • 代码复用 :在多个页面中共享和重用代码,减少重复劳动。
  • 维护升级 :修改公共函数库中的代码,可以自动反映在所有使用该函数的页面上。
  • 模块化 :便于模块化开发,每个模块功能清晰,易于理解和维护。
  • 安全性 :封装核心逻辑,避免在多个页面中直接暴露关键代码。

3.1.2 函数库中的关键函数与使用

common.asp作为一个公共函数库,包含一系列对项目有帮助的关键函数。以下是一个简单的示例,展示如何创建和使用这样的函数库。

<%
Function FormatDate(ByVal inputDate)
    FormatDate = CDate(inputDate) ' 将输入的日期字符串转换为日期格式
End Function

Function EscapeHTML(ByVal inputString)
    ' 转义HTML特殊字符,防止跨站脚本攻击
    EscapeHTML = Replace(inputString, "&", "&amp;")
    EscapeHTML = Replace(EscapeHTML, "<", "&lt;")
    EscapeHTML = Replace(EscapeHTML, ">", "&gt;")
    EscapeHTML = Replace(EscapeHTML, """", """""") ' 双引号需要处理
    EscapeHTML = Replace(EscapeHTML, "'", "&#39;")
End Function
%>

在上述代码中, FormatDate 函数将输入的日期字符串转换为标准的日期格式,而 EscapeHTML 函数则用于防止跨站脚本攻击(XSS),它会替换掉HTML中可能被解释为代码的特殊字符。

在实际使用中,只需要在需要的ASP页面中包含该公共文件即可:

<!-- #include file="common.asp" -->
Dim myDate
myDate = FormatDate(Request.Form("thedate"))
Dim safeText
safeText = EscapeHTML(Request.Form("textinput"))

3.2 index.html QQ登录界面展示

3.2.1 登录界面设计原则

一个良好的登录界面设计对用户体验有着重要影响。QQ登录界面不仅仅是一个简单的表单提交,它需要考虑到用户友好性、安全性、和品牌一致性。

以下是几个关键的设计原则:

  • 简洁性 :避免不必要的装饰,让用户快速识别出登录区域,并知道如何使用。
  • 清晰的指示 :通过文字或图标的说明,指导用户完成登录过程。
  • 安全性提示 :清晰显示安全认证信息,比如小锁图标,确保用户知道他们的数据是安全的。
  • 品牌识别 :保持与QQ品牌一致的色彩和图标风格,提升用户信任感。
  • 反馈机制 :对于输入错误或操作结果,提供明确的反馈信息。

3.2.2 界面元素与功能实现

index.html 页面中,实际的登录界面通常包含以下元素:

  • Logo :展示QQ或合作应用的Logo,加深品牌印象。
  • 文本输入框 :用于用户输入账号信息,如QQ号或手机号。
  • 密码输入框 :用于用户输入密码。
  • 登录按钮 :使用户能够提交登录信息。
  • 忘记密码链接 :提供用户找回密码的途径。
  • 第三方登录选项 :如QQ一键登录,提供快速登录方式。

这些元素的实现通常涉及到HTML、CSS和JavaScript的结合使用,例如:

<form id="loginForm" method="post" action="user.asp">
    <div class="form-group">
        <label for="username">QQ号/手机号</label>
        <input type="text" id="username" name="username" required>
    </div>
    <div class="form-group">
        <label for="password">密码</label>
        <input type="password" id="password" name="password" required>
    </div>
    <div class="form-group">
        <button type="submit" class="btn btn-primary">登录</button>
    </div>
    <!-- 其他元素 -->
</form>

CSS用于美化界面,JavaScript用于增强用户交互,比如动态验证输入内容的合法性、处理登录事件等。

3.3 qq_login.png登录按钮图像

3.3.1 图像设计对用户体验的影响

登录按钮是用户与网站交互的关键点之一,其设计对用户体验有着直接的影响。一个好的按钮设计能够:

  • 明确功能 :直观地告诉用户点击按钮会有怎样的结果。
  • 吸引点击 :通过颜色、形状和位置吸引用户的注意力,鼓励用户进行点击。
  • 风格统一 :与网站整体风格保持一致,提供连贯的视觉体验。
  • 改善可访问性 :确保按钮尺寸、颜色对比度满足可访问性标准,让更多用户能够容易使用。

3.3.2 图像与界面风格的一致性

qq_login.png作为一个登录按钮图像,它需要和页面的整体风格及其它视觉元素保持一致。这样不仅提升了美感,还能加强用户对网站品牌的认知。

以下是一些确保图像风格一致性的要点:

  • 色彩 :使用与网站主色调相协调的颜色。
  • 样式 :按钮的设计要符合网站设计的整体样式,比如扁平化、材料设计等。
  • 尺寸 :按钮大小要适中,既不能过小导致难以点击,也不能过大影响整体布局。
  • 图标 :如果按钮包含图标,确保图标风格与网站整体风格一致。

为了演示如何保持图像与界面风格的一致性,以下是创建一个风格统一的登录按钮图像的代码示例:

<style>
.login-button {
    background-color: #1296DB; /* QQ蓝色 */
    color: white;
    border: none;
    padding: 10px 20px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    font-size: 16px;
    margin: 4px 2px;
    cursor: pointer;
    border-radius: 4px;
}
</style>

<button class="login-button" type="button">QQ登录</button>

在上述代码中,按钮样式被定义在 <style> 标签内,确保了按钮的风格与页面的其他元素保持一致。

4. 技术深化与协议应用

4.1 OAuth2.0授权协议

OAuth2.0协议的概念与应用

OAuth2.0是一种广泛使用的授权协议,它允许用户授权第三方应用访问他们存储在其他服务提供者上的信息,而不需要将用户名和密码提供给第三方。通过使用OAuth2.0,用户可以安全地授权应用程序访问他们的账户数据,而无需共享敏感凭证。

OAuth2.0提供了四种授权模式,包括授权码模式(Authorization Code)、简化模式(Implicit)、密码模式(Resource Owner Password Credentials)和客户端模式(Client Credentials)。在ASP实现QQ一键登录的场景中,通常使用授权码模式。

授权流程的详细解析

授权码模式的流程涉及到三个主要的实体:资源所有者(用户)、客户端(第三方应用)、和授权服务器。下面是详细步骤:

  1. 用户访问客户端应用。
  2. 客户端应用将用户重定向到授权服务器的授权页面。
  3. 用户在授权服务器上进行身份验证并授权客户端应用。
  4. 授权服务器将授权码发送给客户端应用。
  5. 客户端应用使用授权码向授权服务器请求访问令牌。
  6. 授权服务器验证授权码并发放访问令牌。
  7. 客户端应用使用访问令牌访问用户的资源。

保护应用安全的机制

OAuth2.0协议通过以下机制保护应用安全:

  • 使用HTTPS协议传输所有敏感数据。
  • 限制授权码和访问令牌的使用次数和时长。
  • 对访问令牌进行加密处理,仅客户端应用和授权服务器可以解密。
  • 对用户数据进行最小权限授权,即客户端应用仅获得其需要的权限。

4.2 QQ开放平台API集成

API集成的步骤与方法

QQ开放平台提供了丰富的API,让开发者可以集成QQ登录、获取用户信息等功能。以下是集成QQ开放平台API的基本步骤:

  1. 在QQ开放平台注册应用,获取App ID和App Key。
  2. 遵守QQ开放平台的各项规范,尤其是用户隐私和数据安全相关的规定。
  3. 实现QQ登录功能,通过OAuth2.0协议与QQ服务器进行用户授权。
  4. 使用获取的access token调用QQ开放平台提供的API接口。

API使用中遇到的问题与解决方案

在使用QQ开放平台API时可能会遇到以下问题:

  • 获取access token失败 :检查应用程序是否使用了正确的App ID和App Key,并确保通信过程中使用了HTTPS。
  • 获取用户信息失败 :检查用户是否在QQ开放平台中授权了应用所请求的权限。
  • 网络问题导致API调用失败 :实施合理的网络错误处理机制,例如重试逻辑,以及为用户提供清晰的错误提示信息。

4.3 HTTP通信协议

HTTP请求与响应的结构

HTTP(超文本传输协议)是互联网上应用最广泛的协议之一。HTTP请求通常包含请求行、请求头、空行和可选的消息体。响应同样由状态行、响应头、空行和响应体组成。

以下是一个HTTP请求示例:

GET /index.html HTTP/1.1
Host: ***
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8

以下是一个HTTP响应示例:

HTTP/1.1 200 OK
Date: Mon, 23 May 2009 22:38:34 GMT
Server: Apache/2.2.14 (Win32)
Last-Modified: Sat, 20 Nov 2004 07:16:26 GMT
ETag: "3f80f-1b6-3e1cb03b186b0"
Accept-Ranges: bytes
Content-Length: 418
Cache-Control: max-age=21600
Expires: Tue, 23 Jun 2009 10:38:34 GMT
Connection: Keep-Alive
Content-Type: text/html

<html>

理解HTTP状态码的意义

HTTP状态码是响应头中的一个组成部分,表示服务器对请求的处理结果。常见的HTTP状态码包括:

  • 200 OK :请求成功。
  • 301 Moved Permanently :请求的资源已经永久移动。
  • 400 Bad Request :客户端请求有语法错误。
  • 401 Unauthorized :请求需要用户验证。
  • 403 Forbidden :服务器理解请求但拒绝执行。
  • 404 Not Found :服务器无法根据客户端的请求找到资源。
  • 500 Internal Server Error :服务器内部错误。

正确理解和使用HTTP状态码对于开发中调试和维护应用至关重要。

5. 后端开发与数据管理

5.1 数据库操作技术

数据库是存储用户数据的核心组件,在ASP后端开发中,数据库操作是不可或缺的一环。SQL语言作为数据库操作的标准语言,其重要性不言而喻。

5.1.1 SQL语言的基本使用

SQL语言用于与数据库进行交互,包括数据查询、更新、插入和删除。这些操作主要通过以下SQL命令来完成:

-- 查询数据
SELECT * FROM users WHERE username = 'user1';

-- 插入数据
INSERT INTO users (username, password) VALUES ('user1', 'hashed_password');

-- 更新数据
UPDATE users SET password = 'new_hashed_password' WHERE username = 'user1';

-- 删除数据
DELETE FROM users WHERE username = 'user1';

以上示例展示了如何使用SQL进行基本的CRUD(创建、读取、更新、删除)操作。在实际开发中,应该对查询结果进行充分测试,并确保SQL命令的安全性,防止SQL注入等安全威胁。

5.1.2 数据库安全与性能优化

数据库安全和性能优化是保证应用稳定运行的关键。

  • 安全性 :应使用参数化查询来防止SQL注入,还应实施合理的用户权限管理,限制用户对数据库的访问,特别是不要给予非必要的写权限。

  • 性能优化 :建议使用索引来加快查询速度,定期维护数据库,比如重建索引和优化表结构。同时,对于读写密集型的应用,可以考虑读写分离策略,提高数据库的并发处理能力。

5.2 用户授权状态管理

用户授权状态管理涉及到用户会话的创建、维持和验证,是保证用户登录状态安全性的关键。

5.2.1 授权状态的存储机制

用户授权状态通常存储在会话(Session)对象中,会话数据可以是内存中的简单键值对,也可以是存储在数据库中的记录。对于ASP,会话数据可以使用内置的Session对象存储。

<%
' 设置会话变量
Session("user_id") = 123

' 获取会话变量
Dim userId
userId = Session("user_id")
%>

5.2.2 授权状态变更的监控与处理

在用户授权过程中,可能会出现会话过期、用户主动登出或者由于安全问题需要强制用户登出的情况。

  • 会话监控 :可以通过设置会话超时(Session Timeout)来管理会话的有效期。

  • 用户登出 :需要清空会话数据,并销毁会话对象,这可以通过以下代码实现:

<%
' 用户登出,清除会话数据
Session.Abandon()
%>
  • 安全监控 :对于怀疑存在安全风险的会话,应立即终止并通知用户,以保证系统整体的安全性。

后端开发与数据管理是构建稳定可靠应用的基础。通过合理使用SQL语言,确保数据库操作的安全性与效率,同时合理管理用户授权状态,可以极大地提升应用的安全性和用户体验。

本文还有配套的精品资源,点击获取 menu-r.4af5f7ec.gif

简介:QQ一键登录ASP版是一个网页登录解决方案,允许用户利用QQ账号快速登录网站。该方案包括多个文件,每个文件都执行特定功能:qqconnect.asp用于调用QQ API与服务器交互;user.asp处理登录后的用户信息;redirect.asp负责用户授权完成后的重定向;common.asp是公共函数库;index.html展示登录按钮;qq_login.png为登录按钮的图像资源。该功能涉及ASP编程、OAuth2.0授权、QQ开放平台API调用、HTTP通信、数据库操作和状态管理等技术点。

本文还有配套的精品资源,点击获取 menu-r.4af5f7ec.gif

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值