Go错误处理---errors包以及Go记录日志---log包

Go错误处理---errors包

1、error接口

Go语言引入了一个关于错误处理的标准模式,即error接口,该接口定义:

type error interface { 
    Error() string 
}  

对于大多数函数,如果要返回错误,大致可以定义为如下模式,将error作为多种返回值中的最后一个,但这并非是强制要求:

func Foo(param int)(n int, err error) { 
    // ...  
} 

调用时的代码建议如下方式处理错误情况:

n, err := Foo(0)  
 
if err != nil { 
    //  错误处理  
} else { 
    //  使用返回值 n  
} 

详细的源码可见errors包,比较简单。

func New(text string) error {
	return &errorString{text}
}

2、实例详解

自定义error类型

package errors_test

import (
    "fmt"
    "time"
)

// MyError is an error implementation that includes a time and message.
type MyError struct {
    When time.Time
    What string
}

func (e MyError) Error() string {
    return fmt.Sprintf("%v: %v", e.When, e.What)
}

func oops() error {
    return MyError{
        time.Date(1989, 3, 15, 22, 30, 0, 0, time.UTC),
        "the file system has gone away",
    }
}

func Example() { if err := oops(); err != nil { fmt.Println(err) } // Output: 1989-03-15 22:30:00 +0000 UTC: the file system has gone away }

Go记录日志---log包

https://studygolang.com/articles/9184

Golang's log模块主要提供了3类接口。分别是 “Print 、Panic 、Fatal ”,对每一类接口其提供了3中调用方式,分别是 "Xxxx 、 Xxxxln 、Xxxxf",基本和fmt中的相关函数类似,下面是一个Print的示例:

package main

import (
    "log"
)

func main(){
    arr := []int {2,3}
    log.Print("Print array ",arr,"\n")
    log.Println("Println array",arr)
    log.Printf("Printf array with item [%d,%d]\n",arr[0],arr[1])
}

程序输出结果:

2016/12/15 19:46:19 Print array [2 3]
2016/12/15 19:46:19 Println array [2 3]
2016/12/15 19:46:19 Printf array with item [2,3]

对于 log.Fatal 接口,会先将日志内容打印到标准输出,接着调用系统的 os.exit(1) 接口,退出程序并返回状态 1 。但是有一点需要注意,由于是直接调用系统接口退出,defer函数不会被调用,下面是一个Fatal的示例:

package main

import (
	"fmt"
	"log"
)

func test_deferfatal(){
	defer func() {
		fmt.Println("--first--")
	}()
	log.Fatalln("test for defer Fatal")
}

func main() {
	test_deferfatal()
}

程序输出结果:

2016/12/15 19:46:45 test for defer Fatal

可以看到并没有调用defer 函数。

对于log.Panic接口,该函数把日志内容刷到标准错误后调用 panic 函数,下面是一个Panic的示例:

package main

import (
	"fmt"
	"log"
)

func test_deferpanic(){
	defer func() {
		fmt.Println("--first--")
		if err := recover(); err != nil {
			fmt.Println(err)
		}
	}()
	log.Panicln("test for defer Panic")
	defer func() {
		fmt.Println("--second--")
	}()
}

func main() {
	test_deferpanic()
}

程序运行结果:

2016/12/15 19:59:30 test for defer Panic
--first--
test for defer Panic

 可以看到首先输出了“test for defer Panic”,然后第一个defer函数被调用了并输出了“--first--”,但是第二个defer 函数并没有输出,可见在Panic之后声明的defer是不会执行的。

你也可以自定义Logger类型, log.Logger提供了一个New方法用来创建对象:

func New(out io.Writer, prefix string, flag int) *Logger

该函数一共有三个参数:

(1)输出位置out,是一个io.Writer对象,该对象可以是一个文件也可以是实现了该接口的对象。通常我们可以用这个来指定日志输出到哪个文件。
(2)prefix 我们在前面已经看到,就是在日志内容前面的东西。我们可以将其置为 "[Info]" 、 "[Warning]"等来帮助区分日志级别。

(3) flags 是一个选项,显示日志开头的东西,可选的值有:

Ldate         = 1 << iota     // 形如 2009/01/23 的日期
Ltime                         // 形如 01:23:23   的时间
Lmicroseconds                 // 形如 01:23:23.123123   的时间
Llongfile                     // 全路径文件名和行号: /a/b/c/d.go:23 
Lshortfile                    // 文件名和行号: d.go:23
LstdFlags     = Ldate | Ltime // 日期和时间

示例代码:

package main
import (
    "log"
    "os"
)
func main(){
    fileName := "Info_First.log"
    logFile,err  := os.Create(fileName)
    defer logFile.Close()
    if err != nil {
        log.Fatalln("open file error")
    }
    debugLog := log.New(logFile,"[Info]",log.Llongfile)
    debugLog.Println("A Info message here")
    debugLog.SetPrefix("[Debug]")
    debugLog.Println("A Debug Message here ")
}
生成文件:Info_First.log
[Info]F:/works/Golang/src/awesomeProject/main/main.go:57: A Info message here
[Debug]F:/works/Golang/src/awesomeProject/main/main.go:59: A Debug Message here 
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 您的问题看起来像是与编程或Web开发相关的一个参数或选项。('--ignore-ssl-errors')通常是在使用Selenium或其他类似的自动化测试工具时设置的选项,用于忽略HTTPS网站上的SSL错误。它的作用是在自动化测试过程中避免浏览器出现安全警告或错误。 ### 回答2: “--ignore-ssl-errors”是一个命令行选项,常用于网页爬虫或自动化测试工具中。它的作用是忽略SSL证书错误,允许程序继续访问使用了无效或过期证书的网站。 在正常的HTTPS连接中,服务器向客户端提供SSL证书,以确保通信的安全性和可靠性。当SSL证书存在问题(如证书过期、不可信等)时,大多数浏览器或应用程序中止连接并给出警告。然而,某些情况下,我们需要绕过这些SSL错误继续访问网站,这就需要使用“--ignore-ssl-errors”选项了。 该选项的使用方式是在命令行中添加“--ignore-ssl-errors”参数,后面可以跟上其他参数或指令。通过使用该选项,程序忽略SSL错误,继续加载页面或执行其他操作,而不会中断连接或提示错误信息。 需要注意的是,“--ignore-ssl-errors”是一个通过绕过SSL错误来方便用户进行网页爬取或测试的选项。在实际应用中,我们应该尊重和重视SSL证书的安全性,不应过度依赖该选项,以避免潜在的安全风险。 ### 回答3: '--ignore-ssl-errors'是一个用于控制网络爬虫对于SSL证书错误的参数。在进行网络爬取时,有些网站的SSL证书可能过期或无效,这可能导致爬虫程序无法正常访问网站或报错。而使用'--ignore-ssl-errors'参数,可以让爬虫程序忽略SSL证书错误,继续进行访问和数据获取。 通常情况下,爬虫程序验证SSL证书的有效性,确保与服务器的安全连接。但有时候,我们可能希望忽略这些错误,继续访问网站并获取数据。例如,在爬取一些测试网站或不重要的数据时,我们可以使用'--ignore-ssl-errors'参数来避免因为无效SSL证书而中断爬取。 当我们使用'--ignore-ssl-errors'参数时,爬虫程序将不再验证SSL证书的有效性,而是直接访问网站。这意味着,即使网站的SSL证书存在问题,我们仍然可以正常获取数据。但需要注意的是,由于忽略了SSL证书的验证,带来一定的安全风险,因此建议只在特定情况下使用该参数,并且仔细评估潜在的风险。 总之,'--ignore-ssl-errors'是一个控制网络爬虫对SSL证书错误的参数,使用它可以忽略SSL证书错误,在特定情况下继续访问网站并获取数据。需要注意的是,在使用这个参数时要仔细考虑安全性,并确保其使用场景合理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值