亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

首頁 微信小程序 微信開發(fā) 如何使用Koa2開發(fā)微信二維碼掃碼支付

如何使用Koa2開發(fā)微信二維碼掃碼支付

May 29, 2018 am 11:23 AM
koa2 開發(fā)

這次給大家?guī)砣绾问褂肒oa2開發(fā)微信二維碼掃碼支付,使用Koa2開發(fā)微信二維碼掃碼支付的注意事項(xiàng)有哪些,下面就是實(shí)戰(zhàn)案例,一起來看一下。

前段時間在開發(fā)一個功能,要求是通過微信二維碼進(jìn)行掃碼支付。這個情景我們屢見不鮮了,各種電子商城、線下的自動販賣機(jī)等等都會有這個功能。平時只是使用者,如今變?yōu)殚_發(fā)者,也是有不小的坑。所以特此寫一篇博客記錄一下。

注: 要開發(fā)微信二維碼支付,你必須要有相應(yīng)的商戶號的權(quán)限,否則你是無法開發(fā)的。若無相應(yīng)權(quán)限,本文不推薦閱讀。

兩種模式

打開微信支付的文檔,我們可以看到兩種支付模式:模式一和模式二。這二者的流程圖微信的文檔里都給出了(不過說實(shí)話畫得真的有點(diǎn)丑)。

文檔里指出了二者的區(qū)別:

模式一開發(fā)前,商戶必須在公眾平臺后臺設(shè)置支付回調(diào)URL。URL實(shí)現(xiàn)的功能:接收用戶掃碼后微信支付系統(tǒng)回調(diào)的productid和openid。

模式二與模式一相比,流程更為簡單,不依賴設(shè)置的回調(diào)支付URL。商戶后臺系統(tǒng)先調(diào)用微信支付的統(tǒng)一下單接口,微信后臺系統(tǒng)返回鏈接參數(shù)code_url,商戶后臺系統(tǒng)將code_url值生成二維碼圖片,用戶使用微信客戶端掃碼后發(fā)起支付。注意:code_url有效期為2小時,過期后掃碼不能再發(fā)起支付。

模式一是我們平時在網(wǎng)購的時候比較常見的,會彈出一個專門的頁面用于掃碼支付,然后支付成功后這個頁面會再次跳轉(zhuǎn)回回調(diào)頁面,通知你支付成功。第二種的話想對少一些,不過第二種開發(fā)起來相對簡單點(diǎn)。 本文主要介紹模式二的開發(fā) 。

搭建Koa2的簡單開發(fā)環(huán)境

快速搭建Koa2的開發(fā)環(huán)境我推薦可以使用koa-generator 。腳手架能幫我們省去Koa項(xiàng)目一開始的一些基本中間件的書寫步驟。(如果你想學(xué)習(xí)Koa最好自己搭建一個。如果你已經(jīng)會Koa了就可以使用一些快速腳手架了。)

首先全局安裝 koa-generator

npm?install?-g?koa-generator
#or
yarn?global?add?koa-generator

然后找一個目錄用來存放Koa項(xiàng)目,我們打算給這個項(xiàng)目取個名字叫做 koa-wechatpay ,然后就可以輸入 koa2 koa-wechatpay 。然后腳手架會自動創(chuàng)建相應(yīng)文件夾 koa-wechatpay ,并生成基本骨架。進(jìn)入這個文件夾,安裝相應(yīng)的插件。輸入:

npm?install
#or
yarn

接著你可以輸入 npm start 或者 yarn start 來運(yùn)行項(xiàng)目(默認(rèn)監(jiān)聽在3000端口)。

如果不出意外,你的項(xiàng)目跑起來了,然后我們用postman測試一下:

這條路由是在 routes/index.js 里。

如果你看到了

{
?"title":?"koa2?json"
}

就說明沒問題。(如果有問題,檢查一下是不是端口被占用了等等。)

接下來在 routes 文件夾里我們新建一個 wechatpay.js 的文件用來書寫我們的流程。

簽名

跟微信的服務(wù)器交流很關(guān)鍵的一環(huán)是簽名必須正確,如果簽名不正確,那么一切都白搭。

首先我們需要去公眾號的后臺獲取我們所需要的如下相應(yīng)的id或者key的信息。其中 notify_urlserver_ip 是用于當(dāng)我們支付成功后,微信會主動往這個url post 支付成功的信息。

簽名算法如下:https://pay.weixin.qq.com/wiki/doc/api/native.php?chapter=4_3

為了簽名正確,我們需要安裝一下 md5 。

npm?install?md5?--save
#or
yarn?add?md5
const?md5?=?require('md5')
const?appid?=?'xxx'
const?mch_id?=?'yyy'
const?mch_api_key?=?'zzz'
const?notify_url?=?'http://xxx/api/notify'?//?服務(wù)端可訪問的域名和接口
const?server_ip?=?'xx.xx.xx.xx'?//?服務(wù)端的ip地址
const?trade_type?=?'NATIVE'?//?NATIVE對應(yīng)的是二維碼掃碼支付
let?body?=?'XXX的充值支付'?//?用于顯示在支付界面的提示詞

然后開始寫簽名函數(shù):

const?signString?=?(fee,?ip,?nonce)?=>?{
?let?tempString?=?`appid=${appid}&body=${body}&mch_id=${mch_id}&nonce_str=${nonce}&notify_url=${notify_url}&out_trade_no=${nonce}&spbill_create_ip=${ip}&total_fee=${fee}&trade_type=${trade_type}&key=${mch_api_key}`
?return?md5(tempString).toUpperCase()
}

其中 fee 是要充值的費(fèi)用,以分為單位。比如要充值1塊錢, fee 就是100。ip是個比較隨意的選項(xiàng),只要符合規(guī)則的ip經(jīng)過測試都是可以的,下文里我用的是 server_ip 。 nonce 就是微信要求的不重復(fù)的32位以內(nèi)的字符串,通常可以使用訂單號等唯一標(biāo)識的字符串。

由于跟微信的服務(wù)器交流都是用xml來交流,所以現(xiàn)在我們要手動組裝一下post請求xml :

const?xmlBody?=?(fee,?nonce_str)?=>?{
?const?xml?=?`
?<xml>
?<appid>${appid}</appid>
?<body>${body}</body>
?<mch_id>${mch_id}</mch_id>
?<nonce_str>${nonce_str}</nonce_str>
?<notify_url>${notify_url}</notify_url>
?<out_trade_no>${nonce_str}</out_trade_no>
?<total_fee>${fee}</total_fee>
?<spbill_create_ip>${server_ip}</spbill_create_ip>
?<trade_type>NATIVE</trade_type>
?<sign>${signString(fee,?server_ip,?nonce_str)}</sign>
?</xml>
?`
?return?{
?xml,
?out_trade_no:?nonce_str
?}
}

如果你怕自己的簽名的 xml 串有問題,可以提前在微信提供的簽名校驗(yàn)工具里先校驗(yàn)一遍,看看是否能通過。

發(fā)送請求

因?yàn)樾枰⑿欧?wù)端發(fā)請求,所以我選擇了 axios 這個在瀏覽器端和node端都能發(fā)起ajax請求的庫。

安裝過程不再贅述。繼續(xù)在 wechatpay.js 寫發(fā)請求的邏輯。

由于微信給我們返回的也將是一個xml格式的字符串。所以我們需要預(yù)先寫好解析函數(shù),將xml解析成js對象。為此你可以安裝一個 xml2js 。安裝過程跟上面的類似,不再贅述。

微信會給我們返回一個諸如下面格式的 xml 字符串:

<xml><return_code><![CDATA[SUCCESS]]></return_code>
<return_msg><![CDATA[OK]]></return_msg>
<appid><![CDATA[wx742xxxxxxxxxxxxx]]></appid>
<mch_id><![CDATA[14899xxxxx]]></mch_id>
<nonce_str><![CDATA[R69QXXXXXXXX6O]]></nonce_str>
<sign><![CDATA[79F0891XXXXXX189507A184XXXXXXXXX]]></sign>
<result_code><![CDATA[SUCCESS]]></result_code>
<prepay_id><![CDATA[wx152316xxxxxxxxxxxxxxxxxxxxxxxxxxx]]></prepay_id>
<trade_type><![CDATA[NATIVE]]></trade_type>
<code_url><![CDATA[weixin://wxpay/xxxurl?pr=dQNakHH]]></code_url>
</xml>

我們的目標(biāo)是轉(zhuǎn)為如下的js對象,好讓我們用js來操作數(shù)據(jù):

{
?return_code:?'SUCCESS',?//?SUCCESS?或者?FAIL
?return_msg:?'OK',
?appid:?'wx742xxxxxxxxxxxxx',
?mch_id:?'14899xxxxx',
?nonce_str:?'R69QXXXXXXXX6O',
?sign:?'79F0891XXXXXX189507A184XXXXXXXXX',
?result_code:?'SUCCESS',
?prepay_id:?'wx152316xxxxxxxxxxxxxxxxxxxxxxxxxxx',
?trade_type:?'NATIVE',
?code_url:?'weixin://wxpay/xxxurl?pr=dQNakHH'?//?用于生成支付二維碼的鏈接
}

于是我們寫一個函數(shù),調(diào)用 xml2js 來解析xml:

//?將XML轉(zhuǎn)為JS對象
const?parseXML?=?(xml)?=>?{
?return?new?Promise((res,?rej)?=>?{
?xml2js.parseString(xml,?{trim:?true,?explicitArray:?false},?(err,?json)?=>?{
?if?(err)?{
?rej(err)
?}?else?{
?res(json.xml)
?}
?})
?})
}

上面的代碼返回了一個 Promise 對象,因?yàn)?xml2js 的操作是在回調(diào)函數(shù)里返回的結(jié)果,所以為了配合Koa2的 async 、 await ,我們可以將其封裝成一個 Promise 對象,將解析完的結(jié)果通過 resolve 返回回去。這樣就能用 await 來取數(shù)據(jù)了:

const?axios?=?require('axios')
const?url?=?'https://api.mch.weixin.qq.com/pay/unifiedorder'?//?微信服務(wù)端地址
const?pay?=?async?(ctx)?=>?{
?const?form?=?ctx.request.body?//?通過前端傳來的數(shù)據(jù)
?const?orderNo?=?'XXXXXXXXXXXXXXXX'?//?不重復(fù)的訂單號
?const?fee?=?form.fee?//?通過前端傳來的費(fèi)用值
?const?data?=?xmlBody(fee,?orderNo)?//?fee是費(fèi)用,orderNo是訂單號(唯一)
?const?res?=?await?axios.post(url,?{
?data:?data.xml
?}).then(async?res?=>?{
?const?resJson?=?await?parseXML(res.data)
?return?resJson?//?拿到返回的數(shù)據(jù)
?}).catch(err?=>?{
?console.log(err)
?})
?if?(res.return_code?===?'SUCCESS')?{?//?如果返回的
?return?ctx.body?=?{
?success:?true,
?message:?'請求成功',
?code_url:?res.code_url,?//?code_url就是用于生成支付二維碼的鏈接
?order_no:?orderNo?//?訂單號
?}
?}
?ctx.body?=?{
?success:?false,
?message:?'請求失敗'
?}
}
router.post('/api/pay',?pay)
module.exports?=?router

然后我們要將這個router掛載到根目錄的 app.js 里去。

找到之前默認(rèn)的兩個路由,一個 index ,一個 user

const?index?=?require('./routes/index')
const?users?=?require('./routes/users')
const?wechatpay?=?require('./routes/wechatpay')?//?加在這里

然后到頁面底下掛載這個路由:

//?routes
app.use(index.routes(),?index.allowedMethods())
app.use(users.routes(),?users.allowedMethods())
app.use(wechatpay.routes(),?users.allowedMethods())?//?加在這里

于是你就可以通過發(fā)送 /api/pay 來請求二維碼數(shù)據(jù)啦。(如果有跨域需要自己考慮解決跨域方案,可以跟Koa放在同域里,也可以開一層proxy來轉(zhuǎn)發(fā),也可以開CORS頭等等)

注意, 本例里是用前端來生成二維碼,其實(shí)也可以通過后端生成二維碼,然后再返回給前端。不過為了簡易演示,本例采用前端通過獲取 code_url 后,在前端生成二維碼。

展示支付二維碼

前端我用的是 Vue ,當(dāng)然你可以選擇你喜歡的前端框架。這里關(guān)注點(diǎn)在于通過拿到剛才后端傳過來的 code_url 來生成二維碼。

在前端,我使用的是 @xkeshi/vue-qrcode 這個庫來生成二維碼。它調(diào)用特別簡單:

import?VueQrcode?from?'@xkeshi/vue-qrcode'
export?default?{
?components:?{
?VueQrcode
?},
?//?...其他代碼
}

然后就可以在前端里用 <vue-qrcode> 的組件來生成二維碼了:

<vue-qrcode :value="codeUrl" :options="{ size: 200 }">

放到Dialog里就是這樣的效果:

文本是我自己添加的

?

付款成功自動刷新頁面

有兩種將支付成功寫入數(shù)據(jù)庫的辦法。

一種是在打開了掃碼對話框后,不停向微信服務(wù)端輪詢支付結(jié)果,如果支付成功,那么就向后端發(fā)起請求,告訴后端支付成功,讓后端寫入數(shù)據(jù)庫。

一種是后端一直開著接口,等微信主動給后端的 notify_url 發(fā)起post請求,告訴后端支付結(jié)果,讓后端寫入數(shù)據(jù)庫。然后此時前端向后端輪詢的時候應(yīng)該是去數(shù)據(jù)庫取輪詢該訂單的支付結(jié)果,如果支付成功就關(guān)閉Dialog。

第一種比較簡單但是不安全:試想萬一用戶支付成功的同時關(guān)閉了頁面,或者用戶支付成功了,但是網(wǎng)絡(luò)有問題導(dǎo)致前端沒法往后端發(fā)支付成功的結(jié)果,那么后端就一直沒辦法寫入支付成功的數(shù)據(jù)。

第二種雖然麻煩,但是保證了安全。所有的支付結(jié)果都必須等微信主動向后端通知,后端存完數(shù)據(jù)庫后再返回給前端消息。這樣哪怕用戶支付成功的同時關(guān)閉了頁面,下次再打開的時候,由于數(shù)據(jù)庫已經(jīng)寫入了,所以拿到的也是支付成功的結(jié)果。

所以 付款成功自動刷新頁面 這個部分我們分為兩個部分來說:

前端部分

Vue的data部分

data:?{
?payStatus:?false,?//?未支付成功
?retryCount:?0,?//?輪詢次數(shù),從0-200
?orderNo:?'xxx',?//?從后端傳來的order_no
?codeUrl:?'xxx'?//?從后端傳來的code_url
}

在methods里寫一個查詢訂單信息的方法:

//?...
handleCheckBill?()?{
?return?setTimeout(()?=>?{
?if?(!this.payStatus?&&?this.retryCount?< 120) {
 this.retryCount += 1
 axios.post(&#39;/api/check-bill&#39;, { // 向后端請求訂單支付信息
 orderNo: this.orderNo
 })
 .then(res =>?{
?if?(res.data.success)?{
?this.payStatus?=?true
?location.reload()?//?偷懶就用reload重新刷新頁面
?}?else?{
?this.handleCheckBill()
?}
?}).catch(err?=>?{
?console.log(err)
?})
?}?else?{
?location.reload()
?}
?},?1000)
}

在打開二維碼Dialog的時候,這個方法就啟用了。然后就開始輪詢。我訂了一個時間,200s后如果還是沒有付款信息也自動刷新頁面。實(shí)際上你可以自己根據(jù)項(xiàng)目的需要來定義這個時間。

后端部分

前端到后端只有一個接口,但是后端有兩個接口。一個是用來接收微信的推送,一個是用來接收前端的查詢請求。

先來寫最關(guān)鍵的微信的推送請求處理。由于我們接收微信的請求是在Koa的路由里,并且是以流的形式傳輸?shù)摹P枰孠oa支持解析xml格式的body,所以需要安裝一個rawbody 來獲取xml格式的body。

//?處理微信支付回傳notify
//?如果收到消息要跟微信回傳是否接收到
const?handleNotify?=?async?(ctx)?=>?{
?const?xml?=?await?rawbody(ctx.req,?{
?length:?ctx.request.length,
?limit:?'1mb',
?encoding:?ctx.request.charset?||?'utf-8'
?})
?const?res?=?await?parseXML(xml)?//?解析xml
?if?(res.return_code?===?'SUCCESS')?{
?if?(res.result_code?===?'SUCCESS')?{?//?如果都為SUCCESS代表支付成功
?//?...?這里是寫入數(shù)據(jù)庫的相關(guān)操作
?//?開始回傳微信
?ctx.type?=?'application/xml'?//?指定發(fā)送的請求類型是xml
?//?回傳微信,告訴已經(jīng)收到
?return?ctx.body?=?`<xml>
?<return_code><![CDATA[SUCCESS]]></return_code>
?<return_msg><![CDATA[OK]]></return_msg>
?</xml>
?`
?}
?}
?//?如果支付失敗,也回傳微信
?ctx.status?=?400
?ctx.type?=?'application/xml'
?ctx.body?=?`<xml>
?<return_code><![CDATA[FAIL]]></return_code>
?<return_msg><![CDATA[OK]]></return_msg>
?</xml>
?`
}
router.post('/api/notify',?handleNotify)

這里的坑就是Koa處理微信回傳的xml。如果不知道是以 raw-body 的形式回傳的,會調(diào)試半天。。

接下來這個就是比較簡單的給前端回傳的了。

const?checkBill?=?async?(ctx)?=>?{
?const?form?=?ctx.request.body
?const?orderNo?=?form.orderNo
?const?result?=?await?數(shù)據(jù)庫操作
?if?(result)?{?//?如果訂單支付成功
?return?ctx.body?=?{
?success:?true
?}
?}
?ctx.status?=?400
?ctx.body?=?{
?success:?false
?}
}
router.post('/api/check-bill',?checkBill)

相信看了本文案例你已經(jīng)掌握了方法,更多精彩請關(guān)注php中文網(wǎng)其它相關(guān)文章!

推薦閱讀:

如何操作Koa2微信公眾號開發(fā)之本地開發(fā)調(diào)試環(huán)境搭建

如何操作Koa2微信公眾號實(shí)現(xiàn)消息管理

以上是如何使用Koa2開發(fā)微信二維碼掃碼支付的詳細(xì)內(nèi)容。更多信息請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強(qiáng)大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級代碼編輯軟件(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
四款值得推薦的AI輔助編程工具 四款值得推薦的AI輔助編程工具 Apr 22, 2024 pm 05:34 PM

這個AI輔助編程工具在這個AI迅速發(fā)展的階段,挖掘出了一大批好用的AI輔助編程工具。AI輔助編程工具能夠提高開發(fā)效率、改善代碼質(zhì)量、降低bug率,是現(xiàn)代軟件開發(fā)過程中的重要助手。今天大姚給大家分享4款A(yù)I輔助編程工具(并且都支持C#語言),希望對大家有所幫助。https://github.com/YSGStudyHards/DotNetGuide1.GitHubCopilotGitHubCopilot是一款A(yù)I編碼助手,可幫助你更快、更省力地編寫代碼,從而將更多精力集中在問題解決和協(xié)作上。Git

AI程序員哪家強(qiáng)?探索Devin、通義靈碼和SWE-agent的潛力 AI程序員哪家強(qiáng)?探索Devin、通義靈碼和SWE-agent的潛力 Apr 07, 2024 am 09:10 AM

2022年3月3日,距世界首個AI程序員Devin誕生不足一個月,普林斯頓大學(xué)的NLP團(tuán)隊(duì)開發(fā)了一個開源AI程序員SWE-agent。它利用GPT-4模型在GitHub存儲庫中自動解決問題。SWE-agent在SWE-bench測試集上的表現(xiàn)與Devin相似,平均耗時93秒,解決了12.29%的問題。SWE-agent通過與專用終端交互,可以打開、搜索文件內(nèi)容,使用自動語法檢查、編輯特定行,以及編寫和執(zhí)行測試。(注:以上內(nèi)容為原內(nèi)容微調(diào),但保留了原文中的關(guān)鍵信息,未超過指定字?jǐn)?shù)限制。)SWE-A

學(xué)習(xí)如何利用Go語言開發(fā)移動應(yīng)用程序 學(xué)習(xí)如何利用Go語言開發(fā)移動應(yīng)用程序 Mar 28, 2024 pm 10:00 PM

Go語言開發(fā)移動應(yīng)用程序教程隨著移動應(yīng)用市場的不斷蓬勃發(fā)展,越來越多的開發(fā)者開始探索如何利用Go語言開發(fā)移動應(yīng)用程序。作為一種簡潔高效的編程語言,Go語言在移動應(yīng)用開發(fā)中也展現(xiàn)出了強(qiáng)大的潛力。本文將詳細(xì)介紹如何利用Go語言開發(fā)移動應(yīng)用程序,并附上具體的代碼示例,幫助讀者快速入門并開始開發(fā)自己的移動應(yīng)用。一、準(zhǔn)備工作在開始之前,我們需要準(zhǔn)備好開發(fā)環(huán)境和工具。首

Go語言前端技術(shù)探秘:前端開發(fā)新視野 Go語言前端技術(shù)探秘:前端開發(fā)新視野 Mar 28, 2024 pm 01:06 PM

Go語言作為一種快速、高效的編程語言,在后端開發(fā)領(lǐng)域廣受歡迎。然而,很少有人將Go語言與前端開發(fā)聯(lián)系起來。事實(shí)上,使用Go語言進(jìn)行前端開發(fā)不僅可以提高效率,還能為開發(fā)者帶來全新的視野。本文將探討使用Go語言進(jìn)行前端開發(fā)的可能性,并提供具體的代碼示例,幫助讀者更好地了解這一領(lǐng)域。在傳統(tǒng)的前端開發(fā)中,通常會使用JavaScript、HTML和CSS來構(gòu)建用戶界面

五大熱門Go語言庫匯總:開發(fā)必備利器 五大熱門Go語言庫匯總:開發(fā)必備利器 Feb 22, 2024 pm 02:33 PM

五大熱門Go語言庫匯總:開發(fā)必備利器,需要具體代碼示例Go語言自從誕生以來,受到了廣泛的關(guān)注和應(yīng)用。作為一門新興的高效、簡潔的編程語言,Go的快速發(fā)展離不開豐富的開源庫的支持。本文將介紹五大熱門的Go語言庫,這些庫在Go開發(fā)中扮演了至關(guān)重要的角色,為開發(fā)者提供了強(qiáng)大的功能和便捷的開發(fā)體驗(yàn)。同時,為了更好地理解這些庫的用途和功能,我們會結(jié)合具體的代碼示例進(jìn)行講

Android開發(fā)最適合的Linux發(fā)行版是哪個? Android開發(fā)最適合的Linux發(fā)行版是哪個? Mar 14, 2024 pm 12:30 PM

Android開發(fā)是一項(xiàng)繁忙而又令人興奮的工作,而選擇一個適合的Linux發(fā)行版來進(jìn)行開發(fā)則顯得尤為重要。在眾多的Linux發(fā)行版中,究竟哪一個最適合Android開發(fā)呢?本文將從幾個方面來探討這一問題,并給出具體的代碼示例。首先,我們來看一下目前流行的幾個Linux發(fā)行版:Ubuntu、Fedora、Debian、CentOS等,它們都有各自的優(yōu)點(diǎn)和特點(diǎn)。

VSCode最適合哪種框架開發(fā)? VSCode最適合哪種框架開發(fā)? Mar 25, 2024 pm 02:03 PM

VSCode是一款功能強(qiáng)大、靈活性高、易于擴(kuò)展的開源代碼編輯器,廣受開發(fā)者青睞。它支持眾多編程語言和框架,能夠滿足不同項(xiàng)目需求。但是,針對不同的框架,VSCode的優(yōu)勢可能有所不同。本文將討論VSCode在不同框架開發(fā)中的適用性,并提供具體的代碼示例。1.ReactReact是一款流行的JavaScript庫,用于構(gòu)建用戶界面。在使用React開發(fā)項(xiàng)目時,

全面指南:詳解Java虛擬機(jī)安裝過程 全面指南:詳解Java虛擬機(jī)安裝過程 Jan 24, 2024 am 09:02 AM

Java開發(fā)必備:詳細(xì)解讀Java虛擬機(jī)安裝步驟,需要具體代碼示例隨著計(jì)算機(jī)科學(xué)和技術(shù)的發(fā)展,Java語言已成為廣泛使用的編程語言之一。它具有跨平臺、面向?qū)ο蟮葍?yōu)點(diǎn),逐漸成為開發(fā)人員的首選語言。在使用Java進(jìn)行開發(fā)之前,首先需要安裝Java虛擬機(jī)(JavaVirtualMachine,JVM)。本文將詳細(xì)解讀Java虛擬機(jī)的安裝步驟,并提供具體的代碼示

See all articles