登录
首页 >  Golang >  Go问答

如何捕获异常并继续而不退出程序

来源:stackoverflow

时间:2024-04-11 19:09:32 288浏览 收藏

今日不肯埋头,明日何以抬头!每日一句努力自己的话哈哈~哈喽,今天我将给大家带来一篇《如何捕获异常并继续而不退出程序》,主要内容是讲解等等,感兴趣的朋友可以收藏或者有更好的建议在评论提出,我都会认真看的!大家一起进步,一起学习!

问题内容

我正在传递文本文件中的网址列表。命令如下

cat urls.txt | ./mygofile

如果发现 url 损坏,它就会停止。如何让它在不退出程序的情况下继续运行?我希望它显示一个简单的错误并继续到下一个 url 而不退出

http://beap.adss.yahoo.com/
http://id.answers.yahoo.com/search
https://brokenurl
http://id.answers.yahoo.com/knowledgesearchservice
http://id.answers.yahoo.com/question/nextquestion
package main

import (
    "log"
    "bufio"
    "bytes"
    "fmt"
    "net/http"
    "os"
    "strings"
    "crypto/tls"
)

func main() {
    passedUrl := bufio.NewScanner(os.Stdin)
    var pUrl string
    for passedUrl.Scan() {
        fmt.Println(passedUrl.Text())
        if strings.Contains(passedUrl.Text(), "://"){
            pUrl = passedUrl.Text()
        } else {
            pUrl = "https://" + passedUrl.Text()
        }

        body := ""
        customTransport := &(*http.DefaultTransport.(*http.Transport))
        customTransport.TLSClientConfig = &tls.Config{InsecureSkipVerify: true}
        client := &http.Client{Transport: customTransport}
        client.CheckRedirect = func(req *http.Request, via []*http.Request) error {
            return http.ErrUseLastResponse
        }

        req, err := http.NewRequest("POST", pUrl, bytes.NewBuffer([]byte(body)))
        if err != nil {
            log.Println(err)
        }

        req.Header.Add("Content-Type", "application/xml; charset=utf-8")
        resp, err := client.Do(req)
        if err != nil {
            log.Println(err)
        }

        defer resp.Body.Close()
        var responseHeaders string
        for headerName, value := range resp.Header {
            responseHeaders += headerName + ": " + value[0] + "\n"
        }

        if strings.Contains(responseHeaders, "text/xml") {
            fmt.Printf("Match Head: ")
            fmt.Printf(pUrl)
            fmt.Println("")
        }
    }
}

下面是我收到的错误


解决方案


现在您的脚本不会中断循环,您只需停止执行并跳到下一个 purl。像这样的东西应该有效:

req.header.add("content-type", "application/xml; charset=utf-8")
resp, err := client.do(req)
if err != nil {
   log.println(err)
   continue // stop here and process next item
}

有关 for loops 的更多信息

您正在打印错误,但忽略它:

resp, err := client.Do(req)
        if err != nil {
            log.Println(err)
        }

此时,resp为nil,因为调用失败。如果有错误,则不应继续处理结果。在if语句中处理此处的错误,或者将错误返回给调用者以便其能够处理。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《如何捕获异常并继续而不退出程序》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>