Как я могу извлечь имя файла из ссылки на скачивание PHP - PullRequest
0 голосов
/ 18 февраля 2019

Я создаю программу на c #, используя веб-браузер для просмотра Moodle моего университета.Я загружаю файлы, используя открытый класс CookieAwareWebClient.class (нашел этот код в Интернете для загрузки авторизованных файлов), но не могу получить правильное имя файла или пример некоторых ссылок - http://somewebsite.com/mod/resource/view.php?id=80824.Когда я нажимаю это в моем обычном браузере Chrome, открывается pdf-файл "http://somewebsite.com/pluginfile.php/186873/mod_resource/content/1/somefile.pdf". Но я не могу найти имя" somefile.pdf ". Как я могу получить исходное имя файла" somefile.pdf ".

моя функция для загрузки файлов

    public void saveFile(String url)
    {
        Uri Url = new Uri(@url);
        String filePath = "c:\\";
        fileName = url.Substring(url.LastIndexOf("/") + 1).Replace("%20", " ").Replace("%28", " ").Replace("%29", " ");
        SaveFileDialog saveFileDialog1 = new SaveFileDialog();
        saveFileDialog1.FileName = fileName;
        if (saveFileDialog1.ShowDialog() == DialogResult.OK)
        {
            filePath = saveFileDialog1.FileName;
            CookieAwareWebClient http = new CookieAwareWebClient(new CookieContainer());
            http.DownloadProgressChanged += new DownloadProgressChangedEventHandler(client_DownloadProgressChanged);
            http.Headers[HttpRequestHeader.ContentType] = "application/x-www-form-urlencoded";
            string response = http.UploadString("http://courseweb.sliit.lk/login/index.php", "username=" + Form1.USERNAME + "&password=" + Form1.PASSWORD + "&submit=submit");
            //http.DownloadFile(Url, filePath);
            http.DownloadFileAsync(Url, filePath);
            this.Text = "Downloading File - " + fileName;
        }
    }

my CookieAwareWebClient.class ниже

using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Text;

namespace Course_Web
{
    public class CookieAwareWebClient : WebClient
    {
        Uri target = new Uri("http://unversitywebsite.com");
        public CookieContainer CookieContainer { get; set; }
        public Uri Uri { get; set; }



        public CookieAwareWebClient()
            : this(new CookieContainer())
        {
        }

        public CookieAwareWebClient(CookieContainer cookies)
        {
            this.CookieContainer = cookies;
        }

        protected override WebRequest GetWebRequest(Uri address)
        {
            WebRequest request = base.GetWebRequest(address);
            if (request is HttpWebRequest)
            {
                (request as HttpWebRequest).CookieContainer = this.CookieContainer;
            }
            HttpWebRequest httpRequest = (HttpWebRequest)request;
            httpRequest.AutomaticDecompression = DecompressionMethods.GZip | DecompressionMethods.Deflate;
            return httpRequest;
        }

        protected override WebResponse GetWebResponse(WebRequest request)
        {
            WebResponse response = base.GetWebResponse(request);
            String setCookieHeader = response.Headers[HttpResponseHeader.SetCookie];

            if (setCookieHeader != null)
            {
                //do something if needed to parse out the cookie.
                if (setCookieHeader != null)
                {
                    Cookie cookie = new Cookie("CookieName", "CookieValue") { Domain = target.Host }; //create cookie
                    this.CookieContainer.Add(cookie);
                }
            }
            return response;
        }
    }
}

1 Ответ

0 голосов
/ 24 февраля 2019

Наконец-то я нашел решение

Я публикую его здесь, потому что он может помочь любому с тем же вопросом.Мой университетский веб-сайт (Moodle) зашифрован).Итак, я вошел на веб-сайт с контролем веб-браузера. Позже я использовал эти куки для преодоления проблемы с шифрованием.

    private String getURL(String url)
    {
        String response;
        CookieContainer jar;
        HttpWebRequest httpWebRequest = WebRequest.Create(url) as HttpWebRequest;
        httpWebRequest.CookieContainer = jar;
        httpWebRequest.AllowAutoRedirect = false;
        httpWebRequest.Method = "HEAD";
        httpWebRequest.CookieContainer.SetCookies(URI,webBrowser1.Document.Cookie);
        HttpWebResponse httpWebResponse = httpWebRequest.GetResponse() as HttpWebResponse;
        response = httpWebResponse.GetResponseHeader("Location");
        if (response.Length == 0) response = url; //check for null String (if server din't response)
        httpWebRequest.Abort();
        return response;
    }

Затем я отправил ответ другой функции, проверив, является ли файл файлом илитогда я скачал его.

    private bool isfile(String url)
    {
        String tmpString = url.Substring(url.LastIndexOf("/") + 1);
        Boolean result = !(tmpString.Contains(".php") || tmpString.Contains(".htm") || tmpString.Contains(".asp") || tmpString.Contains(".cgi") || tmpString.Contains(".shtml") || tmpString.Contains(".jsp") || tmpString.Contains(".pl"));
        return result;
    }
...