网站首页 > 文章中心 > 其它

前后端分离go语言

作者:小编 更新时间:2023-08-31 18:18:13 浏览量:379人看过

一学就会,手把手教你用Go语言调用智能合约

智能合约调用是实现一个 DApp 的关键,一个完整的 DApp 包括前端、后端、智能合约及区块 链系统,智能合约的调用是连接区块链与前后端的关键.

我们先来了解一下智能合约调用的基础原理.智能合约运行在以太坊节点的 EVM 中.所以呢要 想调用合约必须要访问某个节点.

以后端程序为例,后端服务若想连接节点有两种可能,一种是双 方在同一主机,此时后端连接节点可以采用 本地 IPC(Inter-Process Communication,进 程间通信)机制,也可以采用 RPC(Remote Procedure Call,远程过程调用)机制;另 一种情况是双方不在同一台主机,此时只能采用 RPC 机制进行通信.

接着,我们来了解一下智能合约运行的过程.

智能合约的运行过程是后端服务连接某节点,将 智能合约的调用(交易)发送给节点,节点在验证了交易的合法性后进行全网广播,被矿工打包到 区块中代表此交易得到确认,至此交易才算完成.

就像数据库一样,每个区块链平台都会提供主流 开发语言的 SDK(Software Development Kit,软件开发工具包),由于 Geth 本身就是用 Go 语言 编写的,所以呢若想使用 Go 语言连接节点、发交易,直接在工程内导入 go-ethereum(Geth 源码) 包就可以了,剩下的问题就是流程和 API 的事情了.

最后提醒一下大家,智能合约被调用的两个关键点是节点和 SDK.

此时此刻呢介绍如何使用 Go 语言,借助 go-ethereum 源码库来实现智能合约的调用.这是有固定 步骤的,我们先来说一下总体步骤,以下面的合约为例.

步骤 01:编译合约,获取合约 ABI(Application Binary Interface,应用二进制接口). 单击【ABI】按钮拷贝合约 ABI 信息,将其粘贴到文件 calldemo.abi 中(可使用 Go 语言IDE 创建该文件,文件名可自定义,后缀最好使用 abi).

最好能将 calldemo.abi 单独保存在一个目录下,输入"ls"命令只能看到 calldemo.abi 文件,参 考效果如下:

此时此刻呢设置 module 生效和 GOPROXY,命令如下:

在项目工程内,执行初始化,calldemo 可以自定义名称.

学go还是python?

Python和Go都可以学.Python和是动态语言,而Golang属于编译型语言.

① 如果是一名非科班编程初学者,第一次学习编程,请选择Python.因为它入门快,容易上手,资料丰富,涉及领域广泛.对初学者极其友好.

一般情况下,Go的性能比其他两者要好,并发性能也强很多,在后端生态中,后端服务框架、分布式系统的架构设计等方面要强于Python和Ruby.这里并不是说Python和Ruby开发不了大型系统,早期YouTube就是Python开发的,Github主站是由Ruby开发的.

如果用Go进行后端开发,综合来说会省事一些.想起当年我就是因为Ruby在后端分布式服务中的短板,Rails框架并发性能的不足,以及国内Ruby大环境原因,而选择了转Go.

Go最简单,库都挺全且简洁,文档看起来轻松,如果做"严肃"的Web服务端开发,前后端分离,或者分布式微服务开发什么的,那么Go的投入产出比最高,没有之一,效率高,维护方便,多人合作也轻松应对.

Python看起来简单,但学深还是需要时间的,尤其是当你碰到很多用了高级语法的库的时候,你就得搞清这些高级语法对吧,但难度就上来了.当然如果有数据处理/一次性脚本/机器学习方面的需求,用用Python还是不错的.

go语言写后端快不快

比c++快,go用到了协程,而c++只能使用线程,协程切换几乎不占用或很少占用cpu资源,而线程切换却占用cpu资源较多,这就导致了在相同并发数的情况下,go语言开发的程序可以提高cpu的有效工作率,所以go语言做后端快发效率还是比较好的.

开发一个网站!后端用go语言,前端用PHP,Ruby还是python呢?

错!大错特错!

GO、PHP、Ruby、Python 这些都是用于数据处理的编程语言(简称:后端)

用TaskBuilder开发的应用是前后端分离的吗?

是的,使用的前端开发框架是与后台无关的,后台可以使用Java、C#、PHP、Go等多种语言,但请求和响应的数据格式必须满足采用的前端框架的要求.

81.go + vue实现web应用程序

前端框架越来越丰富,前后端分离已经是大多数软件团队采取的模式了.vue使用的场景也越来越多.

go本来使用template模板来进行前端的表现,现在可以用vue来分担很大一部分工作了.

如果go+vue来协同工作的话,需要对vue进行一点设置.比如把{{ }}的方式改为[[ ]]的方式.

首先我们要知道,vue的使用,需要在页面中加载vue.js或vue.min.js

纯静态网页使用vue是这样的(给个html例子)

然后我们实现一个go的简单web服务和模板页面

go服务器还用模板给前台页面提供了一个News结构的数据,数据包括:Title,Content,Author的值.

在index.html页面中,加载vue.js的时候需要带上静态路径 htmlpage

在 new 一个 vue 变量的时候,必须有一句来设置包裹数据的符号,我们这里设置这个符号为[[ ]]

同时,所有需要由 vue 渲染的数据,都写成类似这样的样子

在 go + vue 方式下的完整模板文件 index.html

此页面中{{ }}包裹的数据是由go从后端提供的数据( 例如:{{.Title}}),而[[ ]]包裹的数据,是vue渲染的数据.

只是把 Vue里的数据,改为由go后端提供即可.

运行一下程序,看修改模板后的效果.

以上就是土嘎嘎小编为大家整理的前后端分离go语言相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!

版权声明:倡导尊重与保护知识产权。未经许可,任何人不得复制、转载、或以其他方式使用本站《原创》内容,违者将追究其法律责任。本站文章内容,部分图片来源于网络,如有侵权,请联系我们修改或者删除处理。

编辑推荐

热门文章