Tuesday, 2 January 2018

Getting The Count Of Words And Characters In A Text Using JavaScript

With the below code, when we enter some text in an textbox and click button, we will get the count of words and characters in the text entered. 

<input type="text" id="txtinput" />  
<button onclick="countwords()">  
        Check Count</button>  
<script>
    function countwords() {
        var val = document.getElementById("txtinput").value;
        var words = 0, chars = 0;
        if (val != "") {
            words = val.replace(/\s+/gi, ' ').split(' ').length; // Count words  
            chars = val.length;                                 // Count characters  
        }
        alert(chars + " Characters & " + words + " Words!");
    }  
</script>

Hope this will be helpful!

Simplest Code To Import Data From A Xml File To Dataset

Here is a Simple one line code to import xml file to dataset :-

DataSet ds = new DataSet();  
ds.ReadXml(Server.MapPath("XMLFile.xml"), XmlReadMode.InferSchema); 

Hope this will be helpful!

Updating A Table Using Inner Join In SQL

Sometimes we may need to update some columns in a table in SQL with values from columns of another table. For this purpose we can use inner join with update query as below.

UPDATE t1  
SET t1.somecol1 = t2.somecol2  
FROM table1 t1  
INNER JOIN table2 t2 ON t1.id = t2.id  

With above query, column 'somecol1' of table1 will be updated with values from 'somecol2' of table2 satisfying the inner join condition.

Hope this will be helpful!

Forcing Browsers to Fetch js/css Files From Server Instead of Cache

Sometimes we have to make some changes in our css or js files. After this we upload it to our servers. But while opening our pages in browser, it wont reflect our changes. We may have to clear our browser cache to see that changes. This is not a feasible solution for websites with thousands of visitors. So here is simple tip we can use in our websites.

First declare a global application variable in our global.asax file

void Application_BeginRequest(Object source, EventArgs e)  
{  
    Application["version"] = "1.0";  


Now while including js/css files in our aspx pages, just add a query string with them as follows.

<script src="youjsfilename.js?ver=<%= Application["version"] %>" type="text/javascript"></script>  
   <link href="youcssfilename.css?ver=<%= Application["version"] %>" rel="stylesheet"  
       type="text/css" /> 
        
Now whenever you make changes in these files, you can just change the value of "version" in global file.

void Application_BeginRequest(Object source, EventArgs e)  
{  
    Application["version"] = "1.1";  
}  

Hope this will be helpful!

Selecting Specific set of Rows using OFFSET and FETCH in SQL

We can use OFFSET and FETCH keywords to select specific number of rows in SQL Select query. 

SELECT *  
FROM Tablename  
ORDER BY colname  
OFFSET 0 ROWS  
FETCH NEXT 10 ROWS ONLY  

The above query will returns first 10 records. 

SELECT *  
FROM Tablename  
ORDER BY colname  
OFFSET 10 ROWS  
FETCH NEXT 10 ROWS ONLY  

Above query will returns records 11 to 20.

Likewise you can increase OFFSET values to get next set of records. 

Hope this will be helpful!

Custom sorting of records in SQL using Case Statement

Sometimes we may have to sort records in such a way that we need some records to be always shown at top. At that cases below query may be helpful.

SELECT *   
FROM  Tablename  
ORDER BY CASE WHEN colname = 'Somevalue1' THEN null  
              WHEN colname = 'Somevalue2' THEN '1'  
              ELSE colname END ASC  

Here sorting is based on column 'colname' .

If 'colname' has value 'Somevalue1', it will be always at top as this query treats that value as null.
Similarly 'colname' having value 'Somevalue2', it will be treated as having value '1' and will be assigned in respective position based on that value while sorting.

Hope this will be helpful!

Preview Image files before uploading using Jquery & Html5

Here is a simple script to preview the image files before saving them using jquery & html5

First create a html page and put below fiel upload button and an preview div in it :-

<input type="file" id="imageUpload3" onchange="previewimg(this)" />  
   <br />  
   <div id="dvPreview3" style="margin-top: 40px;">  
   </div>  

Now we write the Jquery function as below :- 

<script>
    function previewimg(evt) {
        var regex = /^([a-zA-Z0-9\s_\\.\-:()])+(.jpg|.jpeg|.gif|.png|.bmp)$/;
        if (regex.test($(evt).val().toLowerCase())) {
            if ($.browser.msie && parseFloat(jQuery.browser.version) <= 9.0) {
                alert("This browser does not support FileReader.");
            }
            else {
                if (typeof (FileReader) != "undefined") {
                    $("#dvPreview3").show();
                    $("#dvPreview3").html("<img/>");
                    var reader = new FileReader();
                    reader.onload = function (e) {
                        $("#dvPreview3 img").attr("src", e.target.result);
                    }
                    reader.readAsDataURL($(evt)[0].files[0]);
                } else {
                    alert("This browser does not support FileReader.");
                }
            }
        } else {
            alert("Please upload a valid image file.");
            $('#imageUpload3').val('');
        }
    }  
</script>  

Now, once you browse images using fileupload control, you can preview images in the bottom div.

Hope this will be helpful!

Checking For Bad/Abuse Words On Form Posting Using An XML File In C#

Here is a simple code snippet to restrict users from entering bad or abuse words on your website forms.

This is very useful in feedback forms, comments sections, etc..

Step 1: Create a aspx page “Bad-words-check.aspx” as below.


<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Bad-words-check.aspx.cs"  
  
Inherits="ResponsiveForms_ASP_NET_Bad_words_Bad_words_check" %>  
    <!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">  
  
    <head id="Head1" runat="server">  
        <title></title>  
        <style>  
            body {  
                font-family: 'Arial';  
            }  
        </style>  
    </head>    
    <body>  
        <form id="form2" runat="server">  
            <div> <textarea runat="server" id="txtmsg" class="txtarea Txtbox" rows="6" cols="50" style="resize: none;  
  
width: 300px; height: 120px;"></textarea> <br /><br />  
                <asp:Button ID="btnpost" ClientIDMode="Static" runat="server" Text="SUBMIT" Width="100px" OnClick="btnpost_Click" /> <br /><br />  
                <asp:Label ID="lblmsg" runat="server" style="color:Red;font-weight:bold;"></asp:Label>  
            </div>  
        </form>  
    </body>  
</html>   


Step 2: Make cs file as below,

using System;  
using System.Collections.Generic;  
using System.Web;  
using System.Web.UI;  
using System.Web.UI.WebControls;  
using System.Xml;  
public partial class ResponsiveForms_ASP_NET_Bad_words_Bad_words_check: System.Web.UI.Page {  
    protected void Page_Load(object sender, EventArgs e) {}  
    protected void btnpost_Click(object sender, EventArgs e) {  
        try {  
            XmlDocument xmlDoc = new XmlDocument(); // Create an XML document object  
            xmlDoc.Load(Server.MapPath("../WordList.xml")); // Load the XML document from the specified file  
            // Get elements  
            XmlNodeList badwords = xmlDoc.GetElementsByTagName("word");  
            for (int i = 0; i < badwords.Count; i++) {  
                if (txtmsg.Value.ToUpperInvariant().Contains(badwords[i].InnerText.ToUpperInvariant())) {  
                    lblmsg.Text = "Your text contains bad/abuse words!";  
                    break;  
                } else lblmsg.Text = "Your text is clean!";  
            }  
        } catch (Exception ex) {}  
    }  
}  

Step 3: Add xml file “WordList.xml” to your project,

Now you can run the page and see the result. If you have any further words to be restricted then you can add it manually to the xml file.

For the source code of the pages and xml file, pelase visit the blog I have written in C-Sharpcorner website - Click here.

Reading Data Of A CSV File Without Saving It In C#

We can read the data of a CSV file without saving it onto a server. Given below are the steps :-

1) Create an aspx page and paste the following code into it. It will create an File upload control and an button.

<asp:FileUpload ID="txt_Upload" runat="server" />  
<asp:Button ID="btnsubmit" Text="Submit" runat="server" OnClick="btnsubmitclick"/>  


2) In the cs file, paste the below method.

protected void btnsubmitclick(object sender, EventArgs e)   
{  
    System.IO.StreamReader myReader = new System.IO.StreamReader(txt_Upload.PostedFile.InputStream);  
    string output = myReader.ReadToEnd();  
    Response.Write(output);  


Once you select an csv file and click on submit button, data from csv file will be read without saving the file to server and will be displayed in the page.

Hope this will be helpful!