コード例 #1
0
ファイル: WebApiAgent.cs プロジェクト: chroske/GYRO-FPS
        /**
         *  リクエストを送信し、レスポンスを受信する
         *
         * @param	url				URL
         * @param	pCallBack	コールバック
         */
        public IEnumerator Fetch( string url, CallBackResponse pCallBack )
        {
            WWW www = new WWW( url );

            // レスポンスが返ってくるまで待つ
            while ( ! www.isDone ){
            yield return www;
            }

            HttpResponseInfo info = new HttpResponseInfo();
            MatchCollection mc = Regex.Matches( www.responseHeaders[ "STATUS" ], "[0-9]{3}" );
            info.code	= ( 0 == mc.Count ) ? 0 : Convert.ToInt32( mc[ 0 ].Value );
            info.str		= String.IsNullOrEmpty( www.error ) ? www.text : www.error;
            info.www	= www;
            pCallBack( info );
        }
コード例 #2
0
        private static void ValidateResponse(HttpClientRequest request)
        {
            Assert.IsNotNull(request.Response);

            //parse the response and validate it is correct
            HttpResponseInfo respInfo = new HttpResponseInfo();

            respInfo.ProcessResponse(request.Response);

            Assert.AreEqual(200, respInfo.Status);

            //parse the response body
            XmlDocument dom;

            HtmlParserHelper.Parse(respInfo, out dom);

            XmlNode title = dom.SelectSingleNode("//title");

            Assert.IsTrue(title.InnerText.Contains("Altoro Mutual: Online Banking Login"));
        }
コード例 #3
0
        private HttpResponseInfo GetResponseInfo(HttpWebResponse httpResponse, string tempFile, long?contentLength)
        {
            var responseInfo = new HttpResponseInfo
            {
                TempFilePath = tempFile,

                StatusCode = httpResponse.StatusCode,

                ContentType = httpResponse.ContentType,

                ContentLength = contentLength
            };

            if (httpResponse.Headers != null)
            {
                SetHeaders(httpResponse.Headers, responseInfo);
            }

            return(responseInfo);
        }
コード例 #4
0
        private async Task CacheResponse(HttpResponseInfo response, string responseCachePath)
        {
            _fileSystem.CreateDirectory(_fileSystem.GetDirectoryName(responseCachePath));

            using (var responseStream = response.Content)
            {
                var memoryStream = _memoryStreamProvider.CreateNew();
                await responseStream.CopyToAsync(memoryStream).ConfigureAwait(false);

                memoryStream.Position = 0;

                using (var fileStream = _fileSystem.GetFileStream(responseCachePath, FileOpenMode.Create, FileAccessMode.Write, FileShareMode.None, true))
                {
                    await memoryStream.CopyToAsync(fileStream).ConfigureAwait(false);

                    memoryStream.Position = 0;
                    response.Content      = memoryStream;
                }
            }
        }
コード例 #5
0
        public virtual T Get(string id)
        {
            string path = "";

            if (String.IsNullOrWhiteSpace(id))
            {
                path = String.Format("{0}/{1}", API_BASE_PATH, Path);
            }
            else
            {
                path = String.Format("{0}/{1}/{2}", API_BASE_PATH, Path, id);
            }

            HttpResponseInfo     resp     = SendRequest("GET", path, null);
            string               jsonData = resp.ResponseBody.ToString();
            JavaScriptSerializer ser      = new JavaScriptSerializer();

            ser.MaxJsonLength = 1024 * 1024 * 1024;
            return(ser.Deserialize <T>(jsonData));
        }
コード例 #6
0
        private Response CreateResponse(HttpResponseInfo responseInfo)
        {
            Response response = new Response();
            string   body     = responseInfo.Body;

            if (responseInfo.ContentType != null && responseInfo.ContentType.StartsWith(JsonMimeType, StringComparison.OrdinalIgnoreCase))
            {
                response = Response.FromJson(body);
            }
            else
            {
                response.Value = body;
            }

            if (response.Value is string)
            {
                response.Value = ((string)response.Value).Replace("\r\n", "\n").Replace("\n", Environment.NewLine);
            }

            return(response);
        }
コード例 #7
0
        public bool ValidateResponse(HttpResponseInfo respInfo)
        {
            bool found = false;

            lock (_lock)
            {
                if (_curMutatedRequestList != null && _curTestJob != null)
                {
                    string testResponse = null;
                    if (respInfo != null)
                    {
                        testResponse = respInfo.ToString();
                    }

                    if (!_tester.IsMultiValidationRule(_curTestJob.TestDef.Validation))
                    {
                        found = _tester.ValidateSingleTest(_curWorkingRawRequest, "\r\nTesting proxy, original not available\r\n",
                                                           new Uri(_curWorkingReqInfo.FullUrl), _curTestJob.ParameterName, _curEntityId, _curTestJob.TestDef, _curMutatedRawReq, testResponse);
                    }
                    else if (_curMutatedRequestList.Count > 1)
                    {
                        List <string> currentRequestTestResponseSet = null;
                        if (!_curTestResponseCollection.TryGetValue(_currentReqIdx, out currentRequestTestResponseSet))
                        {
                            currentRequestTestResponseSet = new List <string>();
                            _curTestResponseCollection.Add(_currentReqIdx, currentRequestTestResponseSet);
                        }
                        currentRequestTestResponseSet.Add(testResponse);


                        if (_curTestResponseCollection[_currentReqIdx].Count == _curMutatedRequestList.Count)
                        {
                            found = _tester.ValidateTest(_curWorkingRawRequest, "\r\nTesting proxy, original not available\r\n",
                                                         new Uri(_curWorkingReqInfo.FullUrl), _curTestJob.ParameterName, _curEntityId, _curTestJob.TestDef, _curMutatedRequestList, _curTestResponseCollection[_currentReqIdx]);
                        }
                    }
                }
            }
            return(found);
        }
コード例 #8
0
        private async Task <HttpResponseInfo> MakeHttpRequest(HttpRequestInfo requestInfo)
        {
            SendingRemoteHttpRequestEventArgs eventArgs = new SendingRemoteHttpRequestEventArgs(null, requestInfo.RequestBody);

            this.OnSendingRemoteHttpRequest(eventArgs);

            HttpMethod         method         = new HttpMethod(requestInfo.HttpMethod);
            HttpRequestMessage requestMessage = new HttpRequestMessage(method, requestInfo.FullUri);

            if (requestInfo.HttpMethod == CommandInfo.GetCommand)
            {
                CacheControlHeaderValue cacheControlHeader = new CacheControlHeaderValue();
                cacheControlHeader.NoCache          = true;
                requestMessage.Headers.CacheControl = cacheControlHeader;
            }

            if (requestInfo.HttpMethod == CommandInfo.PostCommand)
            {
                MediaTypeWithQualityHeaderValue acceptHeader = new MediaTypeWithQualityHeaderValue(JsonMimeType);
                acceptHeader.CharSet = Utf8CharsetType;
                requestMessage.Headers.Accept.Add(acceptHeader);

                byte[] bytes = Encoding.UTF8.GetBytes(eventArgs.RequestBody);
                requestMessage.Content = new ByteArrayContent(bytes, 0, bytes.Length);

                MediaTypeHeaderValue contentTypeHeader = new MediaTypeHeaderValue(JsonMimeType);
                contentTypeHeader.CharSet = Utf8CharsetType;
                requestMessage.Content.Headers.ContentType = contentTypeHeader;
            }

            HttpResponseMessage responseMessage = await this.client.SendAsync(requestMessage);

            HttpResponseInfo httpResponseInfo = new HttpResponseInfo();

            httpResponseInfo.Body = await responseMessage.Content.ReadAsStringAsync();

            httpResponseInfo.ContentType = responseMessage.Content.Headers.ContentType.ToString();
            httpResponseInfo.StatusCode  = responseMessage.StatusCode;
            return(httpResponseInfo);
        }
コード例 #9
0
        //[TestMethod]
        public void TestSendingMultiPartRequest()
        {
            TrafficViewer.Instance.NewTvf();

            TrafficViewer.Instance.TrafficViewerFile.AddRequestResponse(Resources.MultipartRequest, "HTTP/1.1 200 OK\r\nConnection: close\r\n\r\n");

            TrafficStoreProxy httpProxy = new TrafficStoreProxy(TrafficViewer.Instance.TrafficViewerFile);

            httpProxy.Start();

            HttpRequestInfo         reqInfo = new HttpRequestInfo(Resources.MultipartRequest);
            TrafficViewerHttpClient client  = new TrafficViewerHttpClient();

            client.SetProxySettings("127.0.0.1", httpProxy.Port, null);


            HttpResponseInfo respInfo = client.SendRequest(reqInfo);

            Assert.AreEqual(200, respInfo.Status);

            TrafficViewer.Instance.CloseTvf(false);
        }
コード例 #10
0
        private HttpResponseInfo GetResponseInfo(HttpWebResponse httpResponse, Stream content, long?contentLength, IDisposable disposable)
        {
            var responseInfo = new HttpResponseInfo(disposable)
            {
                Content = content,

                StatusCode = httpResponse.StatusCode,

                ContentType = httpResponse.ContentType,

                ContentLength = contentLength,

                ResponseUrl = httpResponse.ResponseUri.ToString()
            };

            if (httpResponse.Headers != null)
            {
                SetHeaders(httpResponse.Headers, responseInfo);
            }

            return(responseInfo);
        }
コード例 #11
0
ファイル: TmdbMovieProvider.cs プロジェクト: xumix/jellyfin
        /// <summary>
        /// Gets the TMDB settings.
        /// </summary>
        /// <returns>Task{TmdbSettingsResult}.</returns>
        internal async Task <TmdbSettingsResult> GetTmdbSettings(CancellationToken cancellationToken)
        {
            if (_tmdbSettings != null)
            {
                return(_tmdbSettings);
            }

            using (HttpResponseInfo response = await GetMovieDbResponse(new HttpRequestOptions
            {
                Url = string.Format(TmdbConfigUrl, TmdbUtils.ApiKey),
                CancellationToken = cancellationToken,
                AcceptHeader = TmdbUtils.AcceptHeader
            }).ConfigureAwait(false))
            {
                using (Stream json = response.Content)
                {
                    _tmdbSettings = await _jsonSerializer.DeserializeFromStreamAsync <TmdbSettingsResult>(json).ConfigureAwait(false);

                    return(_tmdbSettings);
                }
            }
        }
コード例 #12
0
        /// <summary>
        /// Sends the specified request info
        /// </summary>
        /// <param name="source"></param>
        /// <param name="info"></param>
        private void SendRequest(ITrafficDataAccessor source, TVRequestInfo info)
        {
            byte[] reqBytes       = source.LoadRequestData(info.Id);
            string updatedRequest = PatternTracker.Instance.UpdateRequest(Constants.DefaultEncoding.GetString(reqBytes));

            HttpRequestInfo reqInfo = new HttpRequestInfo(updatedRequest);

            reqInfo.IsSecure = info.IsHttps;

            _sessionIdHelper.UpdateSessionIds(reqInfo, _prevRequest, _prevResponse);


            info.RequestTime = DateTime.Now;
            //save the request that will be sent
            source.SaveRequest(info.Id, Constants.DefaultEncoding.GetBytes(updatedRequest));
            try
            {
                _prevResponse = _httpClient.SendRequest(reqInfo);

                _prevRequest = reqInfo;

                //save the request and response
                if (_prevResponse != null)
                {
                    info.ResponseTime = DateTime.Now;
                    PatternTracker.Instance.UpdatePatternValues(_prevResponse);
                    source.SaveResponse(info.Id, _prevResponse.ToArray());
                }
                else
                {
                    source.SaveResponse(info.Id, Constants.DefaultEncoding.GetBytes(_communicationError));
                }
            }
            catch (Exception ex)
            {
                SdkSettings.Instance.Logger.Log(TraceLevel.Error, "Error playing back request {0}", ex.Message);
                source.SaveResponse(info.Id, Constants.DefaultEncoding.GetBytes(Resources.CommunicationError));
            }
        }
コード例 #13
0
        protected HttpResponseInfo MakeHttpRequest(HttpRequestInfo requestInfo)
        {
            var request = CreateHttpWebRequest(requestInfo);

            HttpResponseInfo responseInfo = new HttpResponseInfo();
            HttpWebResponse  webResponse  = null;

            try
            {
                webResponse = request.GetResponse() as HttpWebResponse;
            }
            catch (WebException ex)
            {
                webResponse = ex.Response as HttpWebResponse;
                if (ex.Status == WebExceptionStatus.Timeout)
                {
                    string timeoutMessage = "The HTTP request to the remote WebDriver server for URL {0} timed out after {1} seconds.";
                    throw new WebDriverException(string.Format(CultureInfo.InvariantCulture, timeoutMessage, request.RequestUri.AbsoluteUri, ServerResponseTimeout.TotalSeconds), ex);
                }
                else if (ex.Response == null)
                {
                    string nullResponseMessage = "A exception with a null response was thrown sending an HTTP request to the remote WebDriver server for URL {0}. The status of the exception was {1}, and the message was: {2}";
                    throw new WebDriverException(string.Format(CultureInfo.InvariantCulture, nullResponseMessage, request.RequestUri.AbsoluteUri, ex.Status, ex.Message), ex);
                }
            }

            if (webResponse == null)
            {
                throw new WebDriverException("No response from server for url " + request.RequestUri.AbsoluteUri);
            }
            else
            {
                responseInfo.Body        = GetTextOfWebResponse(webResponse);
                responseInfo.ContentType = webResponse.ContentType;
                responseInfo.StatusCode  = webResponse.StatusCode;
            }

            return(responseInfo);
        }
コード例 #14
0
ファイル: SharedHttpStream.cs プロジェクト: zjklee/jellyfin
        private Task StartStreaming(HttpResponseInfo response, TaskCompletionSource <bool> openTaskCompletionSource, CancellationToken cancellationToken)
        {
            return(Task.Run(async() =>
            {
                try
                {
                    Logger.LogInformation("Beginning {0} stream to {1}", GetType().Name, TempFilePath);
                    using (response)
                        using (var stream = response.Content)
                            using (var fileStream = new FileStream(TempFilePath, FileMode.Create, FileAccess.Write, FileShare.Read))
                            {
                                await StreamHelper.CopyToAsync(
                                    stream,
                                    fileStream,
                                    IODefaults.CopyToBufferSize,
                                    () => Resolve(openTaskCompletionSource),
                                    cancellationToken).ConfigureAwait(false);
                            }
                }
                catch (OperationCanceledException ex)
                {
                    Logger.LogInformation("Copying of {0} to {1} was canceled", GetType().Name, TempFilePath);
                    openTaskCompletionSource.TrySetException(ex);
                }
                catch (Exception ex)
                {
                    Logger.LogError(ex, "Error copying live stream {0} to {1}.", GetType().Name, TempFilePath);
                    openTaskCompletionSource.TrySetException(ex);
                }

                openTaskCompletionSource.TrySetResult(false);

                EnableStreamSharing = false;
                await DeleteTempFiles(new List <string> {
                    TempFilePath
                }).ConfigureAwait(false);
            }));
        }
コード例 #15
0
        public HttpResponseInfo SendRequest(HttpRequestInfo requestInfo)
        {
            int           idx = -1;
            TVRequestInfo currDataSourceInfo = null;

            byte[] response = null;

            while ((currDataSourceInfo = _mockSite.GetNext(ref idx)) != null)
            {
                if (String.Compare(currDataSourceInfo.RequestLine, requestInfo.RequestLine) == 0)
                {
                    response = _mockSite.LoadResponseData(currDataSourceInfo.Id);
                    break;
                }
            }
            HttpResponseInfo respInfo = null;

            if (response != null)
            {
                respInfo = new HttpResponseInfo(response);
            }
            return(respInfo);
        }
コード例 #16
0
        public string SendTest(string mutatedRequest, string host, int port, bool useSSL)
        {
            //do nothing
            _mutatedRequests.Add(mutatedRequest);

            if (mutatedRequest.Contains(PATH_TRAVERSAL))
            {
                return(PATH_TRAVERSAL_RESPONSE);
            }

            HttpRequestInfo testReqInfo = new HttpRequestInfo(mutatedRequest);

            testReqInfo.Host     = host;
            testReqInfo.Port     = port;
            testReqInfo.IsSecure = useSSL;
            HttpResponseInfo respInfo = _httpClient.SendRequest(testReqInfo);

            if (respInfo != null)
            {
                return(respInfo.ToString());
            }
            return(null);
        }
コード例 #17
0
        /// <summary>
        /// Calculates if the current response is different than the original response
        /// </summary>
        /// <param name="responseInfo"></param>
        /// <returns></returns>
        private bool IsDifferentThanOriginalResponse(HttpResponseInfo responseInfo)
        {
            bool isDifferent;

            if (!_trackingReqInfo.ResponseStatus.Equals(responseInfo.Status.ToString()))
            {
                isDifferent = true;
            }
            else if (ResponseLengthIsSignificantlyDifferent(responseInfo, _trackingReqInfo))
            {
                isDifferent = true;
            }
            else             //calculate response similarity
            {
                byte[] oldRespBytes  = _dataStore.LoadResponseData(_trackingReqInfo.Id);
                string oldRespString = Constants.DefaultEncoding.GetString(oldRespBytes);

                double similarity = ASESimilarityAlgorithm.CalculateSimilarity(oldRespString, responseInfo.ToString());

                isDifferent = similarity < 0.98;
            }
            return(isDifferent);
        }
コード例 #18
0
        private TVRequestInfo SaveRequest(string description, HttpRequestInfo reqInfo, bool isSecure, string testResponse, DateTime requestTime, DateTime responseTime, string validation)
        {
            TVRequestInfo newReqInfo = new TVRequestInfo();

            newReqInfo.Description    = description;
            newReqInfo.Validation     = validation;
            newReqInfo.Host           = reqInfo.Host;
            newReqInfo.ResponseStatus = HttpResponseInfo.GetResponseStatus(testResponse);
            newReqInfo.RequestTime    = requestTime;

            newReqInfo.IsHttps     = isSecure;
            newReqInfo.ThreadId    = Utils.GetCurrentWin32ThreadId().ToString();
            newReqInfo.RequestLine = reqInfo.RequestLine;
            int newId = _trafficFile.AddRequestInfo(newReqInfo);

            _trafficFile.SaveRequest(newId, Constants.DefaultEncoding.GetBytes(reqInfo.ToString(false)));
            if (!String.IsNullOrWhiteSpace(testResponse))
            {
                _trafficFile.SaveResponse(newId, Constants.DefaultEncoding.GetBytes(testResponse));
                newReqInfo.ResponseTime = responseTime;
            }
            return(newReqInfo);
        }
コード例 #19
0
        public void Test_HttpClient_ResponseBody_ChunkedResponse()
        {
            ByteArrayBuilder builder = new ByteArrayBuilder();

            HttpRequestInfo  reqInfo  = new HttpRequestInfo("GET /chunked HTTP/1.1");
            HttpResponseInfo respInfo = new HttpResponseInfo(Resources.ChunkedResponse);

            HttpRequestInfo  receivedReqInfo;
            HttpResponseInfo receivedResponseInfo;

            SendTestRequestToMockProxy(reqInfo, respInfo, out receivedReqInfo, out receivedResponseInfo);

            Assert.IsNotNull(receivedResponseInfo);

            Assert.IsNull(receivedResponseInfo.Headers["Content-length"]);
            byte[] respBody = receivedResponseInfo.ResponseBody.ToArray();

            Assert.IsNotNull(respBody);

            ValidateChunk("This is the data in the first chunk\r\n", receivedResponseInfo.ResponseBody.ReadChunk());
            ValidateChunk("and this is the second one\r\n", receivedResponseInfo.ResponseBody.ReadChunk());
            ValidateChunk("con", receivedResponseInfo.ResponseBody.ReadChunk());
            ValidateChunk("sequence", receivedResponseInfo.ResponseBody.ReadChunk());
        }
コード例 #20
0
        public HttpResponseInfo SendRequest(HttpRequestInfo request)
        {
            if (_skipHtmlEncoding)
            {
                request.Headers["Accept"] = "application/json;opt=no-html-encoding";
            }

            bool isLogin = request.Path.Equals(LOGIN_PATH);

            if (String.IsNullOrWhiteSpace(_asmRestSettings.AscSessionId) && !isLogin)
            {
                Login();
            }

            if (!isLogin)
            {
                SetSessionIds(request);
            }
            request.HostAndPort = _asmRestSettings.HostAndPort;
            request.IsSecure    = true;
            IHttpClient client = GetHttpClient();

            HttpResponseInfo respInfo = client.SendRequest(request);

            if (respInfo.Status == 401 && !isLogin) //session may have expired, relogin
            {
                Login();
                SetSessionIds(request);
                //try again
                client   = GetHttpClient();
                respInfo = client.SendRequest(request);
            }


            return(respInfo);
        }
コード例 #21
0
        public void TestGETRequestToProxy()
        {
            TrafficViewerFile dataStore            = new TrafficViewerFile();
            TrafficViewerFile mockSite             = new TrafficViewerFile();
            string            testRequest          = "GET http://site.com/a HTTP/1.1\r\n";
            string            expectedResponseLine = "HTTP/1.1 200 OK";

            mockSite.AddRequestResponse(testRequest, expectedResponseLine);

            MockProxy proxy = new MockProxy(dataStore, mockSite);

            proxy.Start();

            IHttpClient httpClient = GetHttpClient(proxy.Port);

            HttpRequestInfo testRequestInfo = new HttpRequestInfo(testRequest);

            HttpResponseInfo respInfo = httpClient.SendRequest(testRequestInfo);

            Assert.AreEqual(200, respInfo.Status);


            proxy.Stop();
        }
コード例 #22
0
        /// <summary>
        /// Writes a XML BLOB similar to
        ///  <response status="200" isFrameset="false" isAttack="false" analyzed="false" parsed="true" errorText="" contentType="HTML" headersBuildable="true" bodyBuildable="false" xmlType="XML" japEncoding="2">
        ///  <body encodeValue="true" value="

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" >
<head id="_ctl0__ctl0_head"><title>
	Altoro Mutual
</title><meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"><link href="style.css" rel="stylesheet" type="text/css" /><meta name="description" content="Altoro Mutual offers a broad range of commercial, private, retail and mortgage banking services to small and middle-market businesses and individuals."></head>
<body style="margin-top:5px;">

<div id="header" style="margin-bottom:5px; width: 99%;">
  <form id="frmSearch" method="get" action="/search.aspx">
	  <table width="100%" border="0" cellpadding="0" cellspacing="0">
		  <tr>
		      <td rowspan="2"><a id="_ctl0__ctl0_HyperLink1" href="default.aspx" style="height:80px;width:183px;"><img src="images/logo.gif" border="0" /></a></td>
			  <td align="right" valign="top">
  			  <a id="_ctl0__ctl0_LoginLink" title="It does not appear that you have properly authenticated yourself.  Please click here to sign in." href="bank/login.aspx" style="color:Red;font-weight:bold;">Sign In</a> | <a id="_ctl0__ctl0_HyperLink3" href="default.aspx?content=inside_contact.htm">Contact Us</a> | <a id="_ctl0__ctl0_HyperLink4" href="feedback.aspx">Feedback</a> | <label for="txtSearch">Search</label>
          <input type="text" name="txtSearch" id="txtSearch" accesskey="S" />
          <input type="submit" value="Go" />
			  </td>
		  </tr>
		  <tr>
			  <td align="right" style="background-image:url(/images/gradient.jpg);padding:0px;margin:0px;"><img id="_ctl0__ctl0_Image1" src="images/header_pic.jpg" border="0" style="height:60px;width:354px;" /></td>
		  </tr>
	  </table>
	</form>
</div>

<div id="wrapper" style="width: 99%;">
    

<table cellspacing="0" width="100%">
  <tr>
    <td width="25%" class="bt br bb"><div id="Header1"><img id="_ctl0__ctl0_Content_Image1" src="images/pf_lock.gif" alt="Secure Login" align="absbottom" border="0" style="height:14px;width:12px;" /> &nbsp; <a id="_ctl0__ctl0_Content_AccountLink" title="You do not appear to have authenticated yourself with the application.  Click here to enter your valid username and password." class="focus" href="bank/login.aspx">ONLINE BANKING LOGIN</a></div></td>
    <td width="25%" class="cc bt br bb"><div id="Header2"><a id="_ctl0__ctl0_Content_LinkHeader2" class="focus" href="default.aspx?content=personal.htm">PERSONAL</a></div></td>
    <td width="25%" class="cc bt br bb"><div id="Header3"><a id="_ctl0__ctl0_Content_LinkHeader3" class="focus" href="default.aspx?content=business.htm">SMALL BUSINESS</a></div></td>
    <td width="25%" class="cc bt bb"><div id="Header4"><a id="_ctl0__ctl0_Content_LinkHeader4" class="focus" href="default.aspx?content=inside.htm">INSIDE ALTORO MUTUAL</a></div></td>
  </tr>
  <tr>
    <td valign="top" class="cc br bb">
        <br style="line-height: 10px;"/>
        <a id="_ctl0__ctl0_Content_CatLink1" class="subheader" href="default.aspx?content=personal.htm">PERSONAL</a>
        <ul class="sidebar">
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink1" href="default.aspx?content=personal_deposit.htm">Deposit Product</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink2" href="default.aspx?content=personal_checking.htm">Checking</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink3" href="default.aspx?content=personal_loans.htm">Loan Products</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink4" href="default.aspx?content=personal_cards.htm">Cards</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink5" href="default.aspx?content=personal_investments.htm">Investments &amp; Insurance</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink6" href="default.aspx?content=personal_other.htm">Other Services</a></li>
        </ul>

        <a id="_ctl0__ctl0_Content_CatLink2" class="subheader" href="default.aspx?content=business.htm">SMALL BUSINESS</a>
        <ul class="sidebar">
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink7" href="default.aspx?content=business_deposit.htm">Deposit Products</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink8" href="default.aspx?content=business_lending.htm">Lending Services</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink9" href="default.aspx?content=business_cards.htm">Cards</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink10" href="default.aspx?content=business_insurance.htm">Insurance</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink11" href="default.aspx?content=business_retirement.htm">Retirement</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink12" href="default.aspx?content=business_other.htm">Other Services</a></li>
        </ul>

        <a id="_ctl0__ctl0_Content_CatLink3" class="subheader" href="default.aspx?content=inside.htm">INSIDE ALTORO MUTUAL</a>
        <ul class="sidebar">
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink13" href="default.aspx?content=inside_about.htm">About Us</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink14" href="default.aspx?content=inside_contact.htm">Contact Us</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink15" href="cgi.exe">Locations</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink16" href="default.aspx?content=inside_investor.htm">Investor Relations</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink17" href="default.aspx?content=inside_press.htm">Press Room</a></li>
            <li><a id="_ctl0__ctl0_Content_MenuHyperLink18" href="default.aspx?content=inside_careers.htm">Careers</a></li>
        </ul>
    </td>
    <td valign="top" colspan="3" class="bb">

    <span id="_ctl0__ctl0_Content_Main_lblContent"><br /><table border=0 cellspacing=0 width="100%">  <tr>    <td width="33%" valign="top">        <b><a href="default.aspx?content=personal_savings.htm">Online Banking with FREE Online Bill Pay </a></b><br />        No stamps, envelopes, or checks to write give you more time to spend on the things you enjoy. <br />        <br />        <center><img src="images/home1.jpg" width="170" height="114" /></center>        <br />        <b><a href="default.aspx?content=personal_loans.htm">Real Estate Financing</a></b><br />        Fast. Simple. Professional. Whether you are preparing to buy, build, purchase land, or construct new space, let Altoro Mutual's premier real estate lenders help with financing. As a regional leader, we know the market, we understand the business, and we have the track record to prove it    </td>    <td width="33%" valign="top">        <center><img src="images/home2.jpg" width="170" height="128" /></center>        <br /><br/>        <b><a href="default.aspx?content=business_cards.htm">Business Credit Cards</a></b><br />        You're always looking for ways to improve your company's bottom line. You want to be informed, improve efficiency and control expenses. Now, you can do it all - with a business credit card account from Altoro Mutual.        <br />        <br />        <b><a href="default.aspx?content=business_retirement.htm">Retirement Solutions</a></b><br />        Retaining good employees is a tough task. See how Altoro Mutual can assist you in accomplishing this feat through effective Retirement Solutions.    </td>    <td width="33%" valign="top">        <b>Privacy and Security </b><br />        The 2000 employees of Altoro Mutual are dedicated to protecting your <a href="default.aspx?content=privacy.htm">privacy</a> and <a href="default.aspx?content=security.htm">security</a>. We pledge to provide you with the information and resources that you need to help secure your information and keep it confidential.  This is our promise.        <br /><br />        <center><img src="images/home3.jpg" width="170" height="113" /></center><br /><br />        <b><a href="survey_questions.aspx">Win an 8GB iPod Nano</a></b>        <br />        Completing this short survey will enter you in a draw for 1 of 50 iPod Nanos.  We look forward to hearing your important feedback.        <br /><br />    </td>  </tr></table></span>

    </td>
  </tr>
</table>


</div>

<div id="footer" style="width: 99%;">
    <a id="_ctl0__ctl0_HyperLink5" href="default.aspx?content=privacy.htm">Privacy Policy</a>
    &nbsp;&nbsp;|&nbsp;&nbsp;
    <a id="_ctl0__ctl0_HyperLink6" href="default.aspx?content=security.htm">Security Statement</a>
    &nbsp;&nbsp;|&nbsp;&nbsp;
    &copy; 2009 Altoro Mutual, Inc.

    <div class="disclaimer">
        The Altoro Mutual website is published by Watchfire, Inc. for the sole purpose of
        demonstrating the effectiveness of Watchfire products in detecting web application
        vulnerabilities and website defects. This site is not a real banking site. Similarities,
        if any, to third party products and/or websites are purely coincidental. This site is
        provided "as is" without warranty of any kind, either express or implied. Watchfire does
        not assume any risk in relation to your use of this website. For additional Terms of Use,
        please go to <a id="_ctl0__ctl0_HyperLink7" href="http://www.watchfire.com/statements/terms.aspx">http://www.watchfire.com/statements/terms.aspx</a>.<br /><br />

        Copyright &copy; 2009, Watchfire Corporation, All rights reserved.
    </div>
</div>

</body>
</html>" />
        ///  <header name="Date" value="Thu, 28 May 2009 19:36:29 GMT" />
        ///  <header name="Server" value="Microsoft-IIS/6.0" />
        ///  <header name="X-Powered-By" value="ASP.NET" />
        ///  <header name="X-AspNet-Version" value="2.0.50727" />
        ///  <header name="Set-Cookie" value="ASP.NET_SessionId=n0gzurjs2dtehryqs20ypb55; path=/; HttpOnly" />
        ///  <header name="Set-Cookie" value="amSessionId=143629170095; path=/" />
        ///  <header name="Cache-Control" value="no-cache" />
        ///  <header name="Pragma" value="no-cache" />
        ///  <header name="Expires" value="-1" />
        ///  <header name="Content-Type" value="text/html; charset=utf-8" />
        ///  <header name="Content-Length" value="9605" />
        ///  <cookie name="ASP.NET_SessionId" value="n0gzurjs2dtehryqs20ypb55" />
        ///  <cookie name="amSessionId" value="143629170095" />
        /// </response>
        /// </summary>
        /// <param name="writer"></param>
        /// <param name="respInfo"></param>
        protected virtual void WriteResponse(XmlWriter writer, HttpResponseInfo respInfo)
        {

            writer.WriteStartElement("response");
            writer.WriteAttributeString("status", respInfo.Status.ToString());
            writer.WriteAttributeString("isFrameset", "false");
            writer.WriteAttributeString("isAttack", "false");
            writer.WriteAttributeString("analyzed", "false");
            writer.WriteAttributeString("parsed", "true");
            writer.WriteAttributeString("errorText", "");
            writer.WriteAttributeString("contentType", respInfo.Headers["Content-Type"]);
            writer.WriteAttributeString("headersBuildable", "true");
            writer.WriteAttributeString("bodyBuildable", "false");
            writer.WriteAttributeString("xmlType", "XML");
            writer.WriteAttributeString("japEncoding", "2");
            
            //write body
            writer.WriteStartElement("body");
            //writer.WriteAttributeString("encodeValue", "true");
            writer.WriteAttributeString(" compressedBinaryValue", "true");
			writer.WriteAttributeString(" compressedBinary", "true");

			byte[] respBodyBytes = respInfo.ResponseBody.ToArray();




            writer.WriteAttributeString("value", Utils.CompressToBase64String(respBodyBytes??new byte[0]));
            writer.WriteEndElement();

            //write headers
            WriteHeaders(writer, "", -1, respInfo.Headers);

            //end response
            writer.WriteEndElement();
        }
コード例 #23
0
ファイル: HttpClientManager.cs プロジェクト: NickBolles/Emby
        private async Task CacheResponse(HttpResponseInfo response, string responseCachePath)
        {
            _fileSystem.CreateDirectory(Path.GetDirectoryName(responseCachePath));

            using (var responseStream = response.Content)
            {
                using (var fileStream = _fileSystem.GetFileStream(responseCachePath, FileMode.Create, FileAccess.Write, FileShare.Read, true))
                {
                    var memoryStream = new MemoryStream();

                    await responseStream.CopyToAsync(memoryStream).ConfigureAwait(false);

                    memoryStream.Position = 0;
                    await memoryStream.CopyToAsync(fileStream).ConfigureAwait(false);

                    memoryStream.Position = 0;
                    response.Content = memoryStream;
                }
            }
        }
コード例 #24
0
        private void AddASERequest(XmlNode url)
        {
            XmlNode requestNode        = url.SelectSingleNode("option[@enum='esCOTExploreRequest']");
            XmlNode responseNode       = url.SelectSingleNode("option[@enum='esCOTExploreResponse']");
            XmlNode requestTypeNode    = url.SelectSingleNode("option[@enum='elCOTExploreType']");
            XmlNode responseHeaderNode = url.SelectSingleNode("option[@enum='esCOTExploreResponseHeader']");

            ExploreType requestType = (ExploreType)int.Parse(requestTypeNode.Attributes["value"].Value);
            string      description = String.Empty;

            switch (requestType)
            {
            case ExploreType.eETLogin: description = Resources.RecordedLoginPage; break;

            case ExploreType.eETRegularInSession: description = Resources.InSessionPage; break;

            case ExploreType.eETRegular: description = Resources.ManualExplore; break;
            }

            string request = requestNode.Attributes["value"].Value;

            request = Utils.Base64Decode(request);
            HttpRequestInfo reqInfo = new HttpRequestInfo(request);
            TVRequestInfo   tvInfo  = new TVRequestInfo();

            tvInfo.RequestLine = reqInfo.RequestLine;
            tvInfo.ThreadId    = Resources.Settings;
            tvInfo.Description = description;

            RequestResponseBytes data = new RequestResponseBytes();

            data.AddToRequest(request);

            if (responseHeaderNode != null && responseHeaderNode.Attributes["value"] != null)
            {
                data.AddToResponse(responseHeaderNode.Attributes["value"].Value + Environment.NewLine);
            }

            byte[] response = Convert.FromBase64String(responseNode.Attributes["value"].Value);

            response = Utils.DecompressData(response);

            response = Encoding.Convert(Encoding.Unicode, Constants.DefaultEncoding, response);

            data.AddToResponse(response);

            //attempt to parse the response
            try
            {
                HttpResponseInfo respInfo = new HttpResponseInfo();
                respInfo.ProcessResponse(data.RawResponse);
                tvInfo.ResponseStatus = respInfo.Status.ToString();
            }
            catch
            {
                tvInfo.ResponseStatus = "???";
            }

            _tvFile.AddRequestInfo(tvInfo);
            _tvFile.SaveRequest(tvInfo.Id, data);
            _tvFile.SaveResponse(tvInfo.Id, data);
        }
コード例 #25
0
        private void OnServicesReceived(HttpResponseInfo response)
        {
            int abortCount = 0;
            int bytesRead  = 0;

            byte[]        buffer      = new byte[10240];
            StringBuilder servicesXml = new StringBuilder();
            XmlDocument   xmldoc      = new XmlDocument();

            using (var s = response.Content)
            {
                if (response.StatusCode != HttpStatusCode.OK)
                {
                    _logger.Debug("{0}: Couldn't get services list: {1}", HostEndPoint, response.StatusCode);
                    return; // FIXME: This the best thing to do??
                }

                while (true)
                {
                    bytesRead = s.Read(buffer, 0, buffer.Length);
                    servicesXml.Append(Encoding.UTF8.GetString(buffer, 0, bytesRead));
                    try
                    {
                        xmldoc.LoadXml(servicesXml.ToString());
                        break;
                    }
                    catch (XmlException)
                    {
                        // If we can't receive the entire XML within 500ms, then drop the connection
                        // Unfortunately not all routers supply a valid ContentLength (mine doesn't)
                        // so this hack is needed to keep testing our recieved data until it gets successfully
                        // parsed by the xmldoc. Without this, the code will never pick up my router.
                        if (abortCount++ > 50)
                        {
                            return;
                        }
                        _logger.Debug("{0}: Couldn't parse services list", HostEndPoint);
                        System.Threading.Thread.Sleep(10);
                    }
                }

                _logger.Debug("{0}: Parsed services list", HostEndPoint);
                XmlNamespaceManager ns = new XmlNamespaceManager(xmldoc.NameTable);
                ns.AddNamespace("ns", "urn:schemas-upnp-org:device-1-0");
                XmlNodeList nodes = xmldoc.SelectNodes("//*/ns:serviceList", ns);

                foreach (XmlNode node in nodes)
                {
                    //Go through each service there
                    foreach (XmlNode service in node.ChildNodes)
                    {
                        //If the service is a WANIPConnection, then we have what we want
                        string type = service["serviceType"].InnerText;
                        _logger.Debug("{0}: Found service: {1}", HostEndPoint, type);
                        StringComparison c = StringComparison.OrdinalIgnoreCase;
                        // TODO: Add support for version 2 of UPnP.
                        if (type.Equals("urn:schemas-upnp-org:service:WANPPPConnection:1", c) ||
                            type.Equals("urn:schemas-upnp-org:service:WANIPConnection:1", c))
                        {
                            this.controlUrl = service["controlURL"].InnerText;
                            _logger.Debug("{0}: Found upnp service at: {1}", HostEndPoint, controlUrl);
                            try
                            {
                                Uri u = new Uri(controlUrl);
                                if (u.IsAbsoluteUri)
                                {
                                    EndPoint old = hostEndPoint;
                                    this.hostEndPoint = new IPEndPoint(IPAddress.Parse(u.Host), u.Port);
                                    _logger.Debug("{0}: Absolute URI detected. Host address is now: {1}", old, HostEndPoint);
                                    this.controlUrl = controlUrl.Substring(u.GetLeftPart(UriPartial.Authority).Length);
                                    _logger.Debug("{0}: New control url: {1}", HostEndPoint, controlUrl);
                                }
                            }
                            catch
                            {
                                _logger.Debug("{0}: Assuming control Uri is relative: {1}", HostEndPoint, controlUrl);
                            }
                            _logger.Debug("{0}: Handshake Complete", HostEndPoint);
                            return;
                        }
                    }
                }

                //If we get here, it means that we didn't get WANIPConnection service, which means no uPnP forwarding
                //So we don't invoke the callback, so this device is never added to our lists
            }
        }
コード例 #26
0
        public void TestGetAltoroNonChunkedResponseWithChunkedHeader()
        {
            HttpResponseInfo respInfo = new HttpResponseInfo(Resources.AltoroDifChunkedResponse);

            Assert.AreNotEqual(0, respInfo.ResponseBody.Length);
        }
コード例 #27
0
 public void TestGetResponseStatusFromEmptyBytes()
 {
     Assert.AreEqual(String.Empty, HttpResponseInfo.GetResponseStatus(Encoding.UTF8.GetBytes(String.Empty)));
 }
コード例 #28
0
 public void TestGetResponseStatusFromBytes()
 {
     Assert.AreEqual("200", HttpResponseInfo.GetResponseStatus(Encoding.UTF8.GetBytes("HTTP/1.1 200 OK")));
 }
コード例 #29
0
 public void TestGetResponseStatus()
 {
     Assert.AreEqual("200", HttpResponseInfo.GetResponseStatus("HTTP/1.1 200 OK"));
 }
コード例 #30
0
        private HttpResponseInfo MakeHttpRequest(HttpRequestInfo requestInfo)
        {
            HttpWebRequest request = HttpWebRequest.Create(requestInfo.FullUri) as HttpWebRequest;

            if (!string.IsNullOrEmpty(requestInfo.FullUri.UserInfo) && requestInfo.FullUri.UserInfo.Contains(":"))
            {
                string[] userInfo = this.remoteServerUri.UserInfo.Split(new char[] { ':' }, 2);
                request.Credentials     = new NetworkCredential(userInfo[0], userInfo[1]);
                request.PreAuthenticate = true;
            }

            string userAgentString = string.Format(CultureInfo.InvariantCulture, UserAgentHeaderTemplate, ResourceUtilities.AssemblyVersion, ResourceUtilities.PlatformFamily);

            request.UserAgent = userAgentString;
            request.Method    = requestInfo.HttpMethod;
            request.Timeout   = (int)this.serverResponseTimeout.TotalMilliseconds;
            request.Accept    = RequestAcceptHeader;
            request.KeepAlive = this.enableKeepAlive;
            request.Proxy     = this.proxy;
            request.ServicePoint.ConnectionLimit = 2000;
            if (request.Method == CommandInfo.GetCommand)
            {
                request.Headers.Add("Cache-Control", "no-cache");
            }

            SendingRemoteHttpRequestEventArgs eventArgs = new SendingRemoteHttpRequestEventArgs(request, requestInfo.RequestBody);

            this.OnSendingRemoteHttpRequest(eventArgs);

            if (request.Method == CommandInfo.PostCommand)
            {
                string payload = eventArgs.RequestBody;
                byte[] data    = Encoding.UTF8.GetBytes(payload);
                request.ContentType = ContentTypeHeader;
                Stream requestStream = request.GetRequestStream();
                requestStream.Write(data, 0, data.Length);
                requestStream.Close();
            }

            HttpResponseInfo responseInfo = new HttpResponseInfo();
            HttpWebResponse  webResponse  = null;

            try
            {
                webResponse = request.GetResponse() as HttpWebResponse;
            }
            catch (WebException ex)
            {
                webResponse = ex.Response as HttpWebResponse;
                if (ex.Status == WebExceptionStatus.Timeout)
                {
                    string timeoutMessage = "The HTTP request to the remote WebDriver server for URL {0} timed out after {1} seconds.";
                    throw new WebDriverException(string.Format(CultureInfo.InvariantCulture, timeoutMessage, request.RequestUri.AbsoluteUri, this.serverResponseTimeout.TotalSeconds), ex);
                }
                else if (ex.Response == null)
                {
                    string nullResponseMessage = "A exception with a null response was thrown sending an HTTP request to the remote WebDriver server for URL {0}. The status of the exception was {1}, and the message was: {2}";
                    throw new WebDriverException(string.Format(CultureInfo.InvariantCulture, nullResponseMessage, request.RequestUri.AbsoluteUri, ex.Status, ex.Message), ex);
                }
            }

            if (webResponse == null)
            {
                throw new WebDriverException("No response from server for url " + request.RequestUri.AbsoluteUri);
            }
            else
            {
                responseInfo.Body        = GetTextOfWebResponse(webResponse);
                responseInfo.ContentType = webResponse.ContentType;
                responseInfo.StatusCode  = webResponse.StatusCode;
            }

            return(responseInfo);
        }
コード例 #31
0
        private void RequestHandlerThread()
        {
            while (IsListening)
            {
                HttpRequestInfo  reqInfo   = null;
                HttpResponseInfo respInfo  = null;
                int thisThreadRequestIndex = -1;
                lock (_lock)
                {
                    reqInfo = null;
                    if (_requestsToTest.Count > 0)
                    {
                        thisThreadRequestIndex = _requestsToTest.Dequeue();
                        _currentTestReqIdx     = thisThreadRequestIndex;
                        reqInfo  = _requestIndex[thisThreadRequestIndex];
                        respInfo = _responseIndex[thisThreadRequestIndex];
                    }
                }

                if (reqInfo != null)
                {
                    bool   isSecure   = reqInfo.IsSecure;
                    string rawRequest = reqInfo.ToString();

                    string rawResponse = respInfo != null?respInfo.ToString() : String.Empty;

                    if (ShouldBeTested(rawRequest))
                    {
                        //parse parameters
                        reqInfo          = new HttpRequestInfo(rawRequest, true);
                        reqInfo.IsSecure = isSecure;
                        int hash = reqInfo.GetHashCode(TrafficServerMode.IgnoreCookies);
                        lock (_lock)
                        {
                            if (_testedRequestHashes.Contains(hash))
                            {
                                HttpServerConsole.Instance.WriteLine(LogMessageType.Warning,
                                                                     "Request already tested: '{0}'", reqInfo.FullUrl);
                                continue; //we tested this request before
                            }
                            else
                            {
                                _testedRequestHashes.Add(hash);
                            }
                        }
                        Uri reqUri = new Uri(reqInfo.FullUrl);
                        MultiThreadedTestExecution testExecution = new MultiThreadedTestExecution(_tester, rawRequest, rawResponse, reqUri, _numThreads);

                        lock (_lock)
                        {
                            GenerateEntities(thisThreadRequestIndex, reqInfo);
                            testExecution.TestsQueue = _workList[thisThreadRequestIndex];
                        }

                        testExecution.StartTestsAsync();

                        while (testExecution.IsRunning)
                        {
                            if (!IsListening)
                            {
                                testExecution.CancelTests();
                                break;
                            }
                            HttpServerConsole.Instance.WriteLine(LogMessageType.Notification,
                                                                 "Requests in queue: {0}, Tests in queue for current request: {1}, testing with {2} threads.", _requestsToTest.Count, testExecution.TestsQueue.Count, _numThreads);

                            Thread.Sleep(1000);
                        }

                        HttpServerConsole.Instance.WriteLine(LogMessageType.Notification,
                                                             "Test execution completed.");
                    }
                }


                Thread.Sleep(10);
            }
            HttpServerConsole.Instance.WriteLine(LogMessageType.Notification,
                                                 "Drive by Attack Proxy stopped.");
        }
コード例 #32
0
 public StaticRemoteStreamWriter(HttpResponseInfo response)
 {
     _response = response;
 }