草庐IT

php毕业设计

全部标签

php - 无法使用 Golang 连接到 MSSQL 2014(未在 MSSQL 上打开静态端口)

我正在尝试将我的Golang应用程序连接到MSSQL2014。我已经成功使用-https://github.com/denisenkom/go-mssqldb为此,我只在我的MSSQL上启用了一个静态端口,一切都很好,我能够获取数据。但我想要实现的是连接到MSSQL而无需在MSSQL上打开静态端口,因为我的PHP应用程序已经使用PDO完成了此操作。我也尝试使用-https://github.com/minus5/gofreetds但无法在Windows上安装FreeTDS。但即便如此,我还是看到某个地方可以为MSSQL设置一个端口,所以我停止了。我遇到的另一个golangpkg是-ht

php array_map不返回结果数组

我试图用低音替换数组值的间距,然后回忆起同一数组的所有值,但在空间中降低了。输入:$gFontsList=array("-1","AgencyFB","28","AharoniBold","BookshelfSymbol","100","BookshelfSymbol","111","BrowalliaNewBol");functiontoReplaceSpacing($gFontsListValues,$gFontsListIndex){if(gettype($gFontsListValues)==='string'){if(preg_match('//',$gFontsListValues

go - GO 中的开放式设计和可扩展性

我尝试在go中实现某种具有可扩展性的开放式设计范例,但想知道这样做的gopher方法是什么。例如我有一个车辆包。根据可用的实现方式,我想创建一个包含所有可能车辆的数组。在这个例子中,如果只有自行车可用,我想要一个数组[bike]如果还有另一个汽车实现,我想要[bike,car]我真的不知道如何在go中执行此操作。我想到了车辆包中的接口(interface),但我真的不知道如何根据可用的包创建数组。这应该是开放式设计,这样如果有人决定编写另一辆车,一辆卡车,即它会自动在上游工作。所以这是解释问题的一些示例代码:如果没有必要,它们被分成包,它们也可以在同一个包(车辆)中车辆.gopacka

php - golang 上 PHP __METHOD__ 的等价物

这个问题在这里已经有了答案:Howtogetthecurrentfunctionname(3个答案)关闭4年前。是否有一个golang等同于PHP的魔法__METHOD__常量,以获取当前运行的函数?

php - 在PHP中解密由openssl_encrypt加密的AES-256-CBC密文时出现坏 block 大小错误

我有一个PHP模块,它使用openssl_encrypt使用aes-256-cbc加密电子邮件。本模块生成的密文也可以用本模块解密。但是,如果我尝试使用相同的IV和key在Go中使用aes-256-cbc的实现来解密它们,我会得到一个badblocksize错误。block大小应该是16的倍数,但PHP生成的密文不是16的倍数。这是代码packagemainimport("crypto/aes""crypto/cipher""crypto/sha256""encoding/base64""encoding/hex""fmt")var(IV=[]byte("fg3Dk54f4340fKF

Dockerizing 一个面向包的设计去模块应用程序

我正在按照描述的面向包的设计方式尝试go模块here这样多个可执行服务就可以“dockerized”,但我正在努力在一个repo中正确连接。我无法使用这种方法成功构建docker镜像。大多数在线示例都适用于单模块方法,其中main.go和dockerfile位于根文件夹中。我的目录结构是这样的项目1-应用程序接口(interface)-build-服务1-docker文件-服务2-docker文件-命令-服务1-main.go-服务2-main.go-部署-文档-内部的-第三者-go.mod-go.sum-生成文件-vendor#AccepttheGoversionfortheimag

php - 解密在 GOLang 上用 PHP 解密的 AES-CBC-256 Mcrypt_RIJNDAEL

我尝试在go中重写一些在php5.6(CodeIgniter)中编写的旧代码,但我正在忙于解密。我设法从php解码MCRYPT_RIJNDAEL_128去,其中iv大小是16个字符,但我不能在256上这样做-iv是32。我不想使用go_mcrypt因为它对libcryptheader很严格,所以我试过了在CBC模式下使用goclassicencryptlibsAES密码,但在256上它提示IV长度...phpIV有32个字符而不是预期的16个字符..php部分运行良好...private$CIPHER_KEY="12345678901234567890123456789012";pri

php - 从 PHP 的 shell_exec() 函数执行 Golang 二进制文件

我编译了一个带有1个参数的golang二进制文件,生成一个PDF文件,然后将其上传到AWSS3。该二进制文件在shell中完美运行,但是当尝试使用PHP的shell_exec()、exec()、passthru()和service()函数,它不会执行(没有错误消息或日志条目)。我什至尝试从执行二进制文件的PHP的shell_exec调用shell脚本(.sh)(在shell中也能正常工作),但无济于事。权限很好,PHP的shell_exec()适用于所有其他实例。 最佳答案 shell_exec函数可能需要sudo的密码,sudo密

go - map channel 的设计模式?

我正在用golang写一个DNS协议(protocol)解析器,想法是使用这样的映射vartidMapmap[uint16](chan[]byte)所以对于tidMapmap,key是tid(交易ID),value是字节数组channel。这个想法是,一个goroutine会尝试从channel中获取值,另一个goroutine会尝试通过监听每个传入的数据包来读取字节,一旦找到事务ID,就会将响应数据设置到tidMap,因此前一个goroutine会继续处理响应。设计的一个问题是我需要确保channel的缓冲区长度为1,以便可以将额外的值插入channel而不会阻塞。那么如何在tidM

Golang 上的 PHP gzdeflate/gzinflate 功能

我需要在go中实现gzdeflate/gzinflate函数(压缩级别9)我当前的Go实现如下所示:funcgzdeflate(strstring)string{varbbytes.Bufferw,_:=gzip.NewWriterLevel(&b,9)w.Write([]byte(str))w.Close()returnb.String()}funcgzinflate(strstring)string{b:=bytes.NewReader([]byte(str))r,_:=gzip.NewReader(b)bb2:=new(bytes.Buffer)_,_=io.Copy(bb2,r