public string LanguageDetect(string source) { var http = new HttpVarious(); var apiurl = LanguageDetectEndPoint; var headers = new Dictionary <string, string>(); headers.Add("User-Agent", MyCommon.GetUserAgentString()); headers.Add("v", "1.0"); headers.Add("q", source); var content = ""; if (http.GetData(apiurl, headers, out content)) { var serializer = new DataContractJsonSerializer(typeof(LanguageDetectResponse)); try { var res = MyCommon.CreateDataFromJson <LanguageDetectResponse>(content); return(res.ResponseData.Language); } catch (Exception) { return(""); } } return(""); }
public bool Translate(string _from, string _to, string _text, out string buf) { HttpVarious http = new HttpVarious(); string apiurl = TranslateUri + "&text=" + System.Web.HttpUtility.UrlEncode(_text) + "&to=" + _to; string content = ""; if (http.GetData(apiurl, null, out content)) { buf = string.Copy(content); return(true); } buf = null; return(false); }
public bool Translate(string srclng, string dstlng, string source, ref string destination, ref string ErrMsg) { var http = new HttpVarious(); var apiurl = TranslateEndPoint; var headers = new Dictionary <string, string>(); headers.Add("v", "1.0"); ErrMsg = ""; if (string.IsNullOrEmpty(srclng) || string.IsNullOrEmpty(dstlng)) { return(false); } headers.Add("User-Agent", MyCommon.GetUserAgentString()); headers.Add("langpair", srclng + "|" + dstlng); headers.Add("q", source); var content = ""; if (http.GetData(apiurl, headers, out content)) { var serializer = new DataContractJsonSerializer(typeof(TranslateResponse)); TranslateResponse res; try { res = MyCommon.CreateDataFromJson <TranslateResponse>(content); } catch (Exception) { ErrMsg = "Err:Invalid JSON"; return(false); } if (res.ResponseData == null) { ErrMsg = "Err:" + res.ResponseDetails; return(false); } var _body = res.ResponseData.TranslatedText; var buf = HttpUtility.UrlDecode(_body); destination = string.Copy(buf); return(true); } return(false); }
/// <summary> /// BackgroundWorkerから呼び出されるサムネイル画像作成デリゲート /// </summary> /// <param name="args">class CreateImageArgs /// KeyValuePair<string, string> url 元URLとサムネイルURLのKeyValuePair /// List<KeyValuePair<string, Image>> pics 元URLとサムネイル画像のKeyValuePair /// List<KeyValuePair<string, string>> tooltiptext 元URLとツールチップテキストのKeyValuePair /// string errmsg 取得に失敗した際のエラーメッセージ /// </param> /// <returns>サムネイル画像作成に成功した場合はTrue,失敗した場合はFalse /// なお失敗した場合はargs.errmsgにエラーを表す文字列がセットされる</returns> /// <remarks></remarks> private bool instagram_CreateImage(CreateImageArgs args) { // TODO: サムネイル画像読み込み処理を記述します var src = ""; var http = new HttpVarious(); if (http.GetData(args.url.Value, null, out src, 0, out args.errmsg, "")) { var mc = Regex.Match(src, "<meta property=\"og:image\" content=\"(?<url>.+)\" ?/>"); if (mc.Success) { var _img = http.GetImage(mc.Groups["url"].Value, args.url.Key, 0, out args.errmsg); if (_img == null) return false; args.pics.Add(new KeyValuePair<string, Image>(args.url.Key, _img)); args.tooltipText.Add(new KeyValuePair<string, string>(args.url.Key, "")); return true; } else { args.errmsg = "Pattern NotFound"; } } return false; }
/// <summary> /// BackgroundWorkerから呼び出されるサムネイル画像作成デリゲート /// </summary> /// <param name="args">class CreateImageArgs /// KeyValuePair<string, string> url 元URLとサムネイルURLのKeyValuePair /// List<KeyValuePair<string, Image>> pics 元URLとサムネイル画像のKeyValuePair /// List<KeyValuePair<string, string>> tooltiptext 元URLとツールチップテキストのKeyValuePair /// string errmsg 取得に失敗した際のエラーメッセージ /// </param> /// <returns>サムネイル画像作成に成功した場合はTrue,失敗した場合はFalse /// なお失敗した場合はargs.errmsgにエラーを表す文字列がセットされる</returns> /// <remarks></remarks> private bool flickr_CreateImage(CreateImageArgs args) { // TODO: サムネイル画像読み込み処理を記述します //参考: http://tanarky.blogspot.com/2010/03/flickr-urlunavailable.html アグレッシブエンジニア: flickr の画像URL仕様についてまとめ(Unavailable画像) //画像URL仕様 http://farm{farm}.staticflickr.com/{server}/{id}_{secret}_{size}.{extension} //photostreamなど複数の画像がある場合先頭の一つのみ認識と言うことにする //(二つ目のキャプチャ 一つ目の画像はユーザーアイコン) var src = ""; var mc = Regex.Match(args.url.Value, "^http://www.flickr.com/", RegexOptions.IgnoreCase); var http = new HttpVarious(); if (http.GetData(args.url.Value, null, out src, 0, out args.errmsg, "")) { var _mc = Regex.Matches(src, mc.Result(@"http://farm[0-9]+\.staticflickr\.com/[0-9]+/.+?\.([a-zA-Z]+)")); //二つ以上キャプチャした場合先頭の一つだけ 一つだけの場合はユーザーアイコンしか取れなかった if (_mc.Count > 1) { var _img = http.GetImage(_mc[1].Value, args.url.Value, 0, out args.errmsg); if (_img == null) return false; args.pics.Add(new KeyValuePair<string, Image>(args.url.Key, _img)); args.tooltipText.Add(new KeyValuePair<string, string>(args.url.Key, "")); return true; } else { args.errmsg = "Pattern NotFound"; } } return false; }
/// <summary> /// BackgroundWorkerから呼び出されるサムネイル画像作成デリゲート /// </summary> /// <param name="args">class CreateImageArgs /// KeyValuePair<string, string> url 元URLとサムネイルURLのKeyValuePair /// List<KeyValuePair<string, Image>> pics 元URLとサムネイル画像のKeyValuePair /// List<KeyValuePair<string, string>> tooltiptext 元URLとツールチップテキストのKeyValuePair /// string errmsg 取得に失敗した際のエラーメッセージ /// </param> /// <returns>サムネイル画像作成に成功した場合はTrue,失敗した場合はFalse /// なお失敗した場合はargs.errmsgにエラーを表す文字列がセットされる</returns> /// <remarks></remarks> private bool Vimeo_CreateImage(CreateImageArgs args) { // TODO: サムネイル画像読み込み処理を記述します var http = new HttpVarious(); var mc = Regex.Match(args.url.Value, @"http://vimeo\.com/(?<postID>[0-9]+)", RegexOptions.IgnoreCase); var apiurl = "http://vimeo.com/api/v2/video/" + mc.Groups["postID"].Value + ".xml"; var src = ""; string imgurl = null; if (http.GetData(apiurl, null, out src, 0, out args.errmsg, "")) { var xdoc = new XmlDocument(); var sb = new StringBuilder(); try { xdoc.LoadXml(src); try { var tmp = xdoc.SelectSingleNode("videos/video/title").InnerText; if (!string.IsNullOrEmpty(tmp)) { sb.Append(Properties.Resources.VimeoInfoText1); sb.Append(tmp); sb.AppendLine(); } } catch(Exception) { } try { var tmpdate = new DateTime(); if (DateTime.TryParse(xdoc.SelectSingleNode("videos/video/upload_date").InnerText, out tmpdate)) { sb.Append(Properties.Resources.VimeoInfoText2); sb.Append(tmpdate); sb.AppendLine(); } } catch(Exception) { } try { var tmp = xdoc.SelectSingleNode("videos/video/stats_number_of_likes").InnerText; if (!string.IsNullOrEmpty(tmp)) { sb.Append(Properties.Resources.VimeoInfoText3); sb.Append(tmp); sb.AppendLine(); } } catch(Exception) { } try { var tmp = xdoc.SelectSingleNode("videos/video/stats_number_of_plays").InnerText; if (!string.IsNullOrEmpty(tmp)) { sb.Append(Properties.Resources.VimeoInfoText4); sb.Append(tmp); sb.AppendLine(); } } catch(Exception) { } try { var tmp = xdoc.SelectSingleNode("videos/video/stats_number_of_comments").InnerText; if (!string.IsNullOrEmpty(tmp)) { sb.Append(Properties.Resources.VimeoInfoText5); sb.Append(tmp); sb.AppendLine(); } } catch(Exception) { } try { var sec = 0; if (int.TryParse(xdoc.SelectSingleNode("videos/video/duration").InnerText, out sec)) { sb.Append(Properties.Resources.VimeoInfoText6); sb.AppendFormat("{0:d}:{1:d2}", sec / 60, sec % 60); sb.AppendLine(); } } catch(Exception) { } try { var tmp = xdoc.SelectSingleNode("videos/video/thumbnail_medium").InnerText; if (!string.IsNullOrEmpty(tmp)) { imgurl = tmp; } } catch(Exception) { } } catch(Exception) { imgurl = ""; } if (!string.IsNullOrEmpty(imgurl)) { var _img = http.GetImage(imgurl, args.url.Key, 0, out args.errmsg); if (_img == null) return false; args.pics.Add(new KeyValuePair<string, Image>(args.url.Key, _img)); args.tooltipText.Add(new KeyValuePair<string, string>(args.url.Key, sb.ToString().Trim())); return true; } } return false; }
/// <summary> /// BackgroundWorkerから呼び出されるサムネイル画像作成デリゲート /// </summary> /// <param name="args">class CreateImageArgs /// KeyValuePair<string, string> url 元URLとサムネイルURLのKeyValuePair /// List<KeyValuePair<string, Image>> pics 元URLとサムネイル画像のKeyValuePair /// List<KeyValuePair<string, string>> tooltiptext 元URLとツールチップテキストのKeyValuePair /// string errmsg 取得に失敗した際のエラーメッセージ /// </param> /// <returns>サムネイル画像作成に成功した場合はTrue,失敗した場合はFalse /// なお失敗した場合はargs.errmsgにエラーを表す文字列がセットされる</returns> /// <remarks></remarks> private bool TwipplePhoto_CreateImage(CreateImageArgs args) { // TODO: サムネイル画像読み込み処理を記述します var http = new HttpVarious(); var mc = Regex.Match(args.url.Value, "^http://p.twipple.jp/(?<contentId>[0-9a-z]+)", RegexOptions.IgnoreCase); if (mc.Success) { var src = ""; if (http.GetData(args.url.Key, null, out src, 0, out args.errmsg, "")) { var thumbnail_url = ""; var ContentId = mc.Groups["contentId"].Value; var DataDir = new StringBuilder(); // DataDir作成 DataDir.Append("data"); for (int i = 0; i < ContentId.Length; i++) { DataDir.Append("/"); DataDir.Append(ContentId[i]); } // サムネイルURL抽出 thumbnail_url = Regex.Match(src, @"http://p\.twipple\.jp/" + DataDir.ToString() + @"_s\.([a-zA-Z]+)").Value; if (string.IsNullOrEmpty(thumbnail_url)) return false; var _img = http.GetImage(thumbnail_url, args.url.Key, 0, out args.errmsg); if (_img == null) return false; args.pics.Add(new KeyValuePair<string, Image>(args.url.Key, _img)); args.tooltipText.Add(new KeyValuePair<string, string>(args.url.Key, "")); return true; } } return false; }
/// <summary> /// BackgroundWorkerから呼び出されるサムネイル画像作成デリゲート /// </summary> /// <param name="args">class CreateImageArgs /// KeyValuePair<string, string> url 元URLとサムネイルURLのKeyValuePair /// List<KeyValuePair<string, Image>> pics 元URLとサムネイル画像のKeyValuePair /// List<KeyValuePair<string, string>> tooltiptext 元URLとツールチップテキストのKeyValuePair /// string errmsg 取得に失敗した際のエラーメッセージ /// </param> /// <returns>サムネイル画像作成に成功した場合はTrue,失敗した場合はFalse /// なお失敗した場合はargs.errmsgにエラーを表す文字列がセットされる</returns> /// <remarks></remarks> private bool Tumblr_CreateImage(CreateImageArgs args) { // TODO: サムネイル画像読み込み処理を記述します var http = new HttpVarious(); var TargetUrl = args.url.Value; var tmp = http.GetRedirectTo(TargetUrl); while (!TargetUrl.Equals(tmp)) { TargetUrl = tmp; tmp = http.GetRedirectTo(TargetUrl); } var mc = Regex.Match(TargetUrl, @"(?<base>http://.+?\.tumblr\.com/)post/(?<postID>[0-9]+)(/(?<subject>.+?)/)?", RegexOptions.IgnoreCase); var apiurl = mc.Groups["base"].Value + "api/read?id=" + mc.Groups["postID"].Value; var src = ""; string imgurl = null; if (http.GetData(apiurl, null, out src, 0, out args.errmsg, "")) { var xdoc = new XmlDocument(); try { xdoc.LoadXml(src); var type = xdoc.SelectSingleNode("/tumblr/posts/post").Attributes["type"].Value; if (type == "photo") { imgurl = xdoc.SelectSingleNode("/tumblr/posts/post/photo-url").InnerText; } else { args.errmsg = "PostType:" + type; imgurl = ""; } } catch(Exception) { imgurl = ""; } if (!string.IsNullOrEmpty(imgurl)) { var _img = http.GetImage(imgurl, args.url.Key, 0, out args.errmsg); if (_img == null) return false; args.pics.Add(new KeyValuePair<string, Image>(args.url.Key, _img)); args.tooltipText.Add(new KeyValuePair<string, string>(args.url.Key, "")); return true; } } return false; }
/// <summary> /// BackgroundWorkerから呼び出されるサムネイル画像作成デリゲート /// </summary> /// <param name="args">class CreateImageArgs /// KeyValuePair<string, string> url 元URLとサムネイルURLのKeyValuePair /// List<KeyValuePair<string, Image>> pics 元URLとサムネイル画像のKeyValuePair /// List<KeyValuePair<string, string>> tooltiptext 元URLとツールチップテキストのKeyValuePair /// string errmsg 取得に失敗した際のエラーメッセージ /// </param> /// <returns>サムネイル画像作成に成功した場合はTrue,失敗した場合はFalse /// なお失敗した場合はargs.errmsgにエラーを表す文字列がセットされる</returns> /// <remarks></remarks> private bool Tinami_CreateImage(CreateImageArgs args) { // TODO: サムネイル画像読み込み処理を記述します var http = new HttpVarious(); var mc = Regex.Match(args.url.Value, @"^http://www\.tinami\.com/view/(?<ContentId>\d+)$", RegexOptions.IgnoreCase); if (mc.Success) { var src = ""; var ContentInfo = mc.Result("http://api.tinami.com/content/info?api_key=" + ApplicationSettings.TINAMIApiKey + "&cont_id=${ContentId}"); if (http.GetData(ContentInfo, null, out src, 0, out args.errmsg, "")) { var xdoc = new XmlDocument(); var thumbnail_url = ""; try { xdoc.LoadXml(src); var stat = xdoc.SelectSingleNode("/rsp").Attributes.GetNamedItem("stat").InnerText; if (stat == "ok") { if (xdoc.SelectSingleNode("/rsp/content/thumbnails/thumbnail_150x150") != null) { var nd = xdoc.SelectSingleNode("/rsp/content/thumbnails/thumbnail_150x150"); thumbnail_url = nd.Attributes.GetNamedItem("url").InnerText; if (string.IsNullOrEmpty(thumbnail_url)) return false; var _img = http.GetImage(thumbnail_url, args.url.Key); if (_img == null) return false; args.pics.Add(new KeyValuePair<string, Image>(args.url.Key, _img)); args.tooltipText.Add(new KeyValuePair<string, string>(args.url.Key, "")); return true; } else { //エラー処理 エラーメッセージが返ってきた場合はここで処理 if (xdoc.SelectSingleNode("/rsp/err") != null) { args.errmsg = xdoc.SelectSingleNode("/rsp/err").Attributes.GetNamedItem("msg").InnerText; } return false; } } else { // TODO rsp stat=failの際のエラーメッセージ返却はAPI拡張待ち(2011/8/2要望済み) // TODO 後日APIレスポンスを確認し修正すること if (xdoc.SelectSingleNode("/rsp/err") != null) { args.errmsg = xdoc.SelectSingleNode("/rsp/err").Attributes.GetNamedItem("msg").InnerText; } else { args.errmsg = "DeletedOrSuspended"; } return false; } } catch(Exception ex) { args.errmsg = ex.Message; return false; } } } return false; }
/// <summary> /// BackgroundWorkerから呼び出されるサムネイル画像作成デリゲート /// </summary> /// <param name="args">class CreateImageArgs /// KeyValuePair<string, string> url 元URLとサムネイルURLのKeyValuePair /// List<KeyValuePair<string, Image>> pics 元URLとサムネイル画像のKeyValuePair /// List<KeyValuePair<string, string>> tooltiptext 元URLとツールチップテキストのKeyValuePair /// string errmsg 取得に失敗した際のエラーメッセージ /// </param> /// <returns>サムネイル画像作成に成功した場合はTrue,失敗した場合はFalse /// なお失敗した場合はargs.errmsgにエラーを表す文字列がセットされる</returns> /// <remarks></remarks> private bool Pixiv_CreateImage(CreateImageArgs args) { // TODO: サムネイル画像読み込み処理を記述します var src = ""; //illustIDをキャプチャ var mc = Regex.Match(args.url.Value, @"^http://www\.pixiv\.net/(member_illust|index)\.php\?mode=(medium|big)&(amp;)?illust_id=(?<illustId>[0-9]+)(&(amp;)?tag=(?<tag>.+)?)*$", RegexOptions.IgnoreCase); if (mc.Groups["tag"].Value == "R-18" || mc.Groups["tag"].Value == "R-18G") { args.errmsg = "NotSupported"; return false; } else { var http = new HttpVarious(); if (http.GetData(Regex.Replace(mc.Groups[0].Value, "amp;", ""), null, out src, 0, out args.errmsg, "")) { var _mc = Regex.Match(src, mc.Result(@"http://img([0-9]+)\.pixiv\.net/img/.+/${illustId}_[ms]\.([a-zA-Z]+)")); if (_mc.Success) { var _img = http.GetImage(_mc.Value, args.url.Value, 0, out args.errmsg); if (_img == null) return false; args.pics.Add(new KeyValuePair<string, Image>(args.url.Key, _img)); args.tooltipText.Add(new KeyValuePair<string, string>(args.url.Key, "")); return true; } else if (Regex.Match(src, "<span class=//error//>ログインしてください</span>").Success) { args.errmsg = "NotSupported"; } else { args.errmsg = "Pattern NotFound"; } } } return false; }
/// <summary> /// BackgroundWorkerから呼び出されるサムネイル画像作成デリゲート /// </summary> /// <param name="args">class CreateImageArgs /// KeyValuePair<string, string> url 元URLとサムネイルURLのKeyValuePair /// List<KeyValuePair<string, Image>> pics 元URLとサムネイル画像のKeyValuePair /// List<KeyValuePair<string, string>> tooltiptext 元URLとツールチップテキストのKeyValuePair /// string errmsg 取得に失敗した際のエラーメッセージ /// </param> /// <returns>サムネイル画像作成に成功した場合はTrue,失敗した場合はFalse /// なお失敗した場合はargs.errmsgにエラーを表す文字列がセットされる</returns> /// <remarks></remarks> private bool Piapro_CreateImage(CreateImageArgs args) { // TODO: サムネイル画像読み込み処理を記述します var http = new HttpVarious(); var mc = Regex.Match(args.url.Value, @"^http://piapro\.jp/(?:content/[0-9a-z]+|t/[0-9a-zA-Z_\-]+)$"); if (mc.Success) { var src = ""; if (http.GetData(args.url.Key, null, out src, 0, out args.errmsg, "")) { var _mc = Regex.Match(src, "<meta property=\"og:image\" content=\"(?<big_img>http://c1\\.piapro\\.jp/timg/[0-9a-z]+_\\d{14}_0500_0500\\.(?:jpg|png|gif)?)\" />"); if (_mc.Success) { //各画像には120x120のサムネイルがある(多分)ので、URLを置き換える。元々ページに埋め込まれている画像は500x500 var r = new System.Text.RegularExpressions.Regex(@"_\d{4}_\d{4}"); var min_img_url = r.Replace(_mc.Groups["big_img"].Value, "_0120_0120"); var _img = http.GetImage(min_img_url, args.url.Key, 0, out args.errmsg); if (_img == null) return false; args.pics.Add(new KeyValuePair<string, Image>(args.url.Key, _img)); args.tooltipText.Add(new KeyValuePair<string, string>(args.url.Key, "")); return true; } else { args.errmsg = "Pattern NotFound"; } } } return false; }
/// <summary> /// BackgroundWorkerから呼び出されるサムネイル画像作成デリゲート /// </summary> /// <param name="args">class CreateImageArgs /// KeyValuePair<string, string> url 元URLとサムネイルURLのKeyValuePair /// List<KeyValuePair<string, Image>> pics 元URLとサムネイル画像のKeyValuePair /// List<KeyValuePair<string, string>> tooltiptext 元URLとツールチップテキストのKeyValuePair /// string errmsg 取得に失敗した際のエラーメッセージ /// </param> /// <returns>サムネイル画像作成に成功した場合はTrue,失敗した場合はFalse /// なお失敗した場合はargs.errmsgにエラーを表す文字列がセットされる</returns> /// <remarks></remarks> private bool Photozou_CreateImage(CreateImageArgs args) { // TODO: サムネイル画像読み込み処理を記述します var http = new HttpVarious(); var mc = Regex.Match(args.url.Value, @"^http://photozou\.jp/photo/show/(?<userId>[0-9]+)/(?<photoId>[0-9]+)", RegexOptions.IgnoreCase); if (mc.Success) { var src = ""; var show_info = mc.Result("http://api.photozou.jp/rest/photo_info?photo_id=${photoId}"); if (http.GetData(show_info, null, out src, 0, out args.errmsg, "")) { var xdoc = new XmlDocument(); var thumbnail_url = ""; try { xdoc.LoadXml(src); thumbnail_url = xdoc.SelectSingleNode("/rsp/info/photo/thumbnail_image_url").InnerText; } catch(Exception ex) { args.errmsg = ex.Message; thumbnail_url = ""; } if (string.IsNullOrEmpty(thumbnail_url)) return false; var _img = http.GetImage(thumbnail_url, args.url.Key); if (_img == null) return false; args.pics.Add(new KeyValuePair<string, Image>(args.url.Key, _img)); args.tooltipText.Add(new KeyValuePair<string, string>(args.url.Key, "")); return true; } } return false; }
public bool Translate(string srclng, string dstlng, string source, ref string destination, ref string ErrMsg) { var http = new HttpVarious(); var apiurl = TranslateEndPoint; var headers = new Dictionary<string, string>(); headers.Add( "v", "1.0" ); ErrMsg = ""; if ( string.IsNullOrEmpty( srclng ) || string.IsNullOrEmpty( dstlng ) ) { return false; } headers.Add( "User-Agent", MyCommon.GetUserAgentString() ); headers.Add( "langpair", srclng + "|" + dstlng ); headers.Add( "q", source ); var content = ""; if ( http.GetData( apiurl, headers, out content ) ) { var serializer = new DataContractJsonSerializer( typeof(TranslateResponse) ); TranslateResponse res; try { res = MyCommon.CreateDataFromJson<TranslateResponse>( content ); } catch ( Exception ) { ErrMsg = "Err:Invalid JSON"; return false; } if ( res.ResponseData == null ) { ErrMsg = "Err:" + res.ResponseDetails; return false; } var _body = res.ResponseData.TranslatedText; var buf = HttpUtility.UrlDecode( _body ); destination = string.Copy( buf ); return true; } return false; }
public string LanguageDetect(string source) { var http = new HttpVarious(); var apiurl = LanguageDetectEndPoint; var headers = new Dictionary<string, string>(); headers.Add( "User-Agent", MyCommon.GetUserAgentString() ); headers.Add( "v", "1.0" ); headers.Add( "q", source ); var content = ""; if ( http.GetData( apiurl, headers, out content ) ) { var serializer = new DataContractJsonSerializer( typeof(LanguageDetectResponse) ); try { var res = MyCommon.CreateDataFromJson<LanguageDetectResponse>( content ); return res.ResponseData.Language; } catch ( Exception ) { return ""; } } return ""; }
public bool Translate(string _from, string _to, string _text, out string buf) { HttpVarious http = new HttpVarious(); string apiurl = TranslateUri + "&text=" + System.Web.HttpUtility.UrlEncode(_text) + "&to=" + _to; string content = ""; if (http.GetData(apiurl, null, out content)) { buf = string.Copy(content); return true; } buf = null; return false; }