09 Eki 2021 ASP.NET ile HTML'den PDF'e Çevirme İşlemi Kategori: ASP.NET Etiketler: ASP.NETASP.NET 4.0C# 4.0 49 Yorum HTML'den PDF'e dönüşüm işlemini "wkhtmltopdf" ile çok basit bir şekilde yapabiliyoruz. public static string HtmlToPdf(string pdfOutputLocation, string outputFilenamePrefix, string[] urls, string[] options = null, string pdfHtmlToPdfExePath = "C:\\Program Files\\wkhtmltopdf\\bin\\wkhtmltopdf.exe") { string urlsSeparatedBySpaces = string.Empty; try { //Determine inputs if ((urls == null) || (urls.Length == 0)) throw new Exception("No input URLs provided for HtmlToPdf"); else urlsSeparatedBySpaces = String.Join(" ", urls); //Concatenate URLs string outputFolder = pdfOutputLocation; string outputFilename = outputFilenamePrefix + ".PDF"; // assemble destination PDF file name var p = new System.Diagnostics.Process() { StartInfo = { FileName = pdfHtmlToPdfExePath, Arguments = ((options == null) ? "" : String.Join(" ", options)) + " " + urlsSeparatedBySpaces + " " + outputFilename, UseShellExecute = false, // needs to be false in order to redirect output RedirectStandardOutput = true, RedirectStandardError = true, RedirectStandardInput = true, // redirect all 3, as it should be all 3 or none WorkingDirectory = HttpContext.Current.Server.MapPath(outputFolder) } }; p.Start(); // read the output here... var output = p.StandardOutput.ReadToEnd(); var errorOutput = p.StandardError.ReadToEnd(); // ...then wait n milliseconds for exit (as after exit, it can't read the output) p.WaitForExit(100000); // read the exit code, close process int returnCode = p.ExitCode; p.Close(); // if 0 or 2, it worked so return path of pdf if ((returnCode == 0) || (returnCode == 2)) return outputFolder + outputFilename; else throw new Exception(errorOutput); } catch (Exception exc) { throw new Exception("Problem generating PDF from HTML, URLs: " + urlsSeparatedBySpaces + ", outputFilename: " + outputFilenamePrefix, exc); } }Kullanırken de aşağıdaki gibi çağırabiliriz.Parametreler hakkında bilgileri aşağıda bulabilirsiniz.1. Parametre: PDF'in kaydedileceği klasör.2. Parametre: PDF dosyasının adı.3. Parametre: Hangi URL'in PDF'i oluşturulacaksa belirtiyoruz.HtmlToPdf("/uplodas/", "PDFDosyasiAdi", new string[] { "http://www.semgoksu.com" });
10 Eki 2014 ASP.NET "UnobtrusiveValidationMode" Hatası ve Çözümü Kategori: ASP.NET Etiketler: ASP.NET 4.0ASP.NET 1 Yorum ASP.NET uygulamalarında, projemize validation kontrollerinden birini eklediğimiz durumlarda karşımıza "WebForms UnobtrusiveValidationMode requires a ScriptResourceMapping for 'jquery'. Please add a ScriptResourceMapping named jquery(case-sensitive)." hatası çıkacaktır. Bu hatayı iki şekilde çözebiliriz. İlki; Global.asax dosyası içerisinde yer alan Application_Start metodu yazacağımız aşağıdaki kod bloğu ile gerçekleşir.Application_Start metodu uygulamamız ilk çalıştığında çalışmasını istediğimiz kodları içerisinde barındıran metottur.ScriptManager.ScriptResourceMapping.AddDefinition("jquery", new ScriptResourceDefinition {Path = "~/scripts/jquery-1.4.1.min.js",DebugPath = "~/scripts/jquery-1.4.1.js",CdnPath = "http://ajax.microsoft.com/ajax/jQuery/jquery-1.4.1.min.js",CdnDebugPath = "http://ajax.microsoft.com/ajax/jQuery/jquery-1.4.1.js" });Not: Burada jquery’nin kullandığımız sürümünü belirtmemiz gerekmektedir.Diğer çözümse, uygulama ayarlarımızın yer aldığı web.config dosyası içerisinde bulunan <appSettings></appSettings> arasına yazacağımız key ile gerçekleşir.<appSettings><add key="ValidationSettings:UnobtrusiveValidationMode" value="none"/></appSettings>
19 Ağu 2011 Reflection ile Dinamik Tip Oluşturmak Kategori: Yazılım Etiketler: C#C# 4.0ASP.NET 4.0ASP.NET 0 Yorum Projelerimden birinde Developer Express kontrollerinden ASPxGridview'i kullanırken RowDataBound eventinin olmadığını farkettim. Biraz araştırdıktan sonra bu evente karşılık olarak HtmlRowPrepared eventini buldum. Bu event RowDataBound ile aynı işi yapsa da çok yetersiz. Örnek olarak e.Row.DataItem property'si ASPxGridView kontrolün de yer almıyor. Benzer işi yapan GetValue metodu var fakat her defasında da datayı okumak için GetValue metodunu çağırmak pek hoşuma gitmedi açıkcası. Bu sorunu çözmek için bir extension metot yazdım ve her defasında GetValue metodunu çağırmak yerine ilgili nesneyi döndürüyor. Metot generic olduğu için hangi tipte nesne set ederseniz edin size o tipte bir nesne döndürüyor. Her ne kadar Asp.Net kontrolünün yerini tutan bir kontrol olmasa da bu metot sayesinde biraz daha kullanışlı hale gelmiş oldu :) public static T RowData<T>(this ASPxGridViewTableRowEventArgs row) whereT : class, new() { Type originalObject = (newT()).GetType(); // DataSource'a set edilen collection nesnenin tipi T newObject = Activator.CreateInstance<T>(); // Geri döndüreceğimiz tipi oluşturuyoruz foreach (var property in originalObject.GetProperties()) // Property'lere değerlerini set etmek için tüm propertyler arasında gezinelim { if (property.CanWrite) // Property set blogunu içeriyorsa { property.SetValue(newObject, row.GetValue(property.Name), null); } } return(T)newObject; // Oluşturulan tip doldurulduktan sonra geri döndürülür...} İşte bu kadar :)
29 Ara 2010 Bunu mu aramıştınız: ASP.NET Kategori: ASP.NET Etiketler: C#ASP.NET 4.0ADO.NETASP.NETSQL Server 5 Yorum Merhaba arkadaşlar, bu makalemizde arama motorlarının en sevdiğim özelliklerinden biri olan arama yaparken hatalı girdiğimiz kelimeleri düzelterek bize öneriler sunmasıdır. Bizde bu makelemizde bu tarz bir uygulamayı ASP.NET ile yapacağız.Arama motorları hayatımızda pek çok şeyi kolaylaştıran ve bizi aradığımız bilgilere ulaştıran çok önemli bir güç. Bu gücün farkına varan arama motoru geliştiricileri son dönemde kullanıcılarına çok fazla yenilikler sunmaya başladılar. Arama önerileri, bunu mu aramıştınız, fotoğraf arama, dokuman arama vs. bunlardan sadece bir kaçı. Biz bu makalemiz de web uygulamamızda kullanacağımız bir arama motoru hazırlayıp kullanıcılara arama önerileri sunacağız. Yani kullanıcıların yapmış olduğu girişlere uygun sonuç yoksa en yakın sonucu getirip bunu mu aramıştınız diye soracağız.Örneğe geçmeden önce T-SQL’de bulunan 2 fonksiyonu inceleyeceğiz. Soundex ve Difference. SoundexSoundex, iki kelime arasındaki benzerligi ölçebilmek için bize kelime ile ilgili 4 karakterli bir kod döndüren bir fonksiyondur. Bu kod ile birbirine benzeyen kelimeleri eşleştirebiliriz. Bu eşleşme sonucuna biribirine benzeyen kayıtları elde edebiliriz. Aşağıdaki iki satırıda çalıştırdığımız da aynı sonucu verecek. (Sonuç: S500)SELECT SOUNDEX('Sem Göksu')SELECT SOUNDEX('Sen Göksu')DifferenceDifference, Soundex’e benzeyen bir algoritmaya sahip. İki kelime arasında benzerlik oranına göre geriye 0 ile 4 arasında sayısal bir değer döndürür. Bu sonuca göre yapılan aramada benzerlik oranı belli bir değer üzerinde olan kayıtları resultset içerisine alabiliriz.SELECT DIFFERENCE('ASYA GÖKSU', 'AYSA GÖKSU')Bu iki fonksiyon ile, bunu mu aramıştınız özelliğini arama motorumuza ek özellik olarak katabiliriz. Bunun için bir örnek bir proje hazırlayalım. Örneğimizde kullanabileceğimiz bir veritabanı ve tablo hazırlayalım. Benim veritabanım adı Bing, içerikler için kullanacağım tablomun adı da Contents olacak. Tablo içerisinde de 3 alanım olacak: ContentID, Title, Description. (Ben örnek basit olsun diye fazla alan kullanmadım. Siz kendi projelerinizde farklı alanlarda da kullanabilirsiniz)Tablo içerisindeki kayıtlar da aşağıdaki gibidir.Bir ASP.NET projesini oluşturalım. Arama sayfamızın HTML kodları aşağıda gibi olacak. <div> <asp:TextBox ID="txtKeyword" runat="server" Width="320px"></asp:TextBox> <asp:Button ID="btnSearch" runat="server" Text="Ara" OnClick="btnSearch_Click" /> <p><asp:Literal ID="ltlResultText" runat="server"></asp:Literal></p> <asp:Repeater ID="rptResults" runat="server"> <HeaderTemplate> <table> </HeaderTemplate> <ItemTemplate> <tr> <td> <asp:HyperLink ID="hypTitle" runat="server" NavigateUrl="#" Text='<%# Eval("Title") %>'></asp:HyperLink> </td> </tr> <tr> <td> <asp:Literal ID="ltlDescription" runat="server" Text='<%# Eval("Description") %>'></asp:Literal> </td> </tr> </ItemTemplate> <FooterTemplate> </table> </FooterTemplate></asp:Repeater></div>Arama sonuçlarını görüntülemek için butona tıkladığımızda yapacağımız işlemleri yapalım. Ben 2 ayrı metot yazdım. Search ve DidYouMean. Search metodu buton altından çağırılacak. Eğer search metodu arama ile ilgili kayıt bulursa kayıtları listeleyecek. Kayıt bulamazsa DidYouMean isimli metodu çağıracak ve aramaya uygun en yakın kayıt getirilip kullanıcıya arama önerisinde bulunulacak. Arama önerilerini yapmak için de DidYouMean metodu içerisindeki sorguda Diffrence fonksiyonunu kullanacağım. (Diffrence fonksiyonunu kullandığımız için Soundex'e gerek kalmadı. O yüzden bu makale de soundex'i kullanmayacağım,. Daha ileri seviye bir uygulama yaparken ikisini de kullanabiliriz. )protected void btnSearch_Click(object sender, EventArgs e){ Search(txtKeyword.Text.Trim());}[Search() Metodu] public void Search(string keyword){ SqlConnection cnn = new SqlConnection("Server=.; Database=Bing; Trusted_Connection=yes"); SqlCommand cmd = new SqlCommand(); cmd.CommandText = "Select * From Contents Where Title Like '%' + @Keyword+ '%'"; cmd.Parameters.AddWithValue("@Keyword", keyword); cmd.Connection = cnn; SqlDataAdapter da = new SqlDataAdapter(cmd); DataTable dt = new DataTable(); da.Fill(dt); if (dt != null && dt.Rows.Count > 0) { rptResults.DataSource = dt; rptResults.DataBind(); } else { DidYouMean(keyword); // Bunu mu aramıştınız metoduna çağrıda bulunuyoruz. rptResults.DataSource = null; rptResults.DataBind(); }}[DidYouMean Metodu]public void DidYouMean(string keyword){ SqlConnection cnn = new SqlConnection("Server=.; Database=Bing; Trusted_Connection=yes"); SqlCommand cmd = new SqlCommand(); cmd.CommandText = "Select top 1 * From Contents Where DIFFERENCE(Title, @Keyword) >=3"; cmd.Parameters.AddWithValue("@Keyword", keyword); cmd.Connection = cnn; SqlDataAdapter da = new SqlDataAdapter(cmd); DataTable dt = new DataTable(); da.Fill(dt); if (dt != null && dt.Rows.Count > 0) { ltlResultText.Text = string.Format("Bunu mu aramıştınız: <u style='color:red'>{0}</u>", dt.Rows[0]["Title"].ToString()); } else { ltlResultText.Text = "Arama kriterlerinize uygun sonuç bulunamadı."; }}Tablodaki kayıtlarımıza uygun bir arama yapalım. Örneğin, Alex yazalım ve sonuca bakalım.Hatalı bir arama yapalım. Örneğin, Alex Le Sonsuza.T-SQL’de Difference komutunu kullanarak kullanıcılara benzer sonuçlara göre arama önerileri sunmuş olduk. Makalemizin sonuna geldik, bir sonraki makalede görüşmek üzere. ASP.NET ile kalın JSem GÖKSUaskisem@hotmail.com www.semgoksu.com | www.yazilimgunlugu.com
18 Ara 2010 Method not found: 'Void System.Web.UI.HtmlControls.HtmlForm.set_Action(System.String)'. Kategori: Yazılım Etiketler: ASP.NET 2.0ASP.NET 4.0ASP.NET 1 Yorum Yakın zamanda projelerimden birinde Method not found: 'Void System.Web.UI.HtmlControls.HtmlForm.set_Action(System.String)' hatasını aldım. Local'de problem yoktu ama sunucu da hata veriyordu. Biraz araştırdıktan sonra olayın çözümü çokta basitmiş. Sunucuya .NET Framework 3.5 SP 1 yükleyince sorun düzeldi. Eğer karşınıza çıkarsa hiç aramayın direk NET Framework 3.5 SP 1 yükleyin :)