Archive for the ‘Technical’ Category

Accessing Web services using SQL CLR

August 14, 2014 Leave a comment

Problem : wanted to trigger event from SQL server to windows service, rather windows service is looking for a data changed as we always do.

Solution : After doing R&D, proposed following solution, which is still having one problem.  This i am writing because, i couldn’t find any complete guide to do this on the internet. just part by part explaining articles were there. Here i am going to combine all those and create complete guide.

Step 1 : Create windows service with REST based web service. (Not going to explain REST services here and hope you are familiar with REST)

Step 2 : You should have running REST service in your machine. As a example i will get the service URL as http://localhost:8090/Sync/NotifyNow/ 

Now just entering this URL on the browser, you should be able to invoke service’s method.

Step 3 : Create  following class, This will handle call from SQL server and pass to windows service. simply call the URL of REST service

using System;
using System.Data.SqlTypes;
using Microsoft.SqlServer.Server;
using System.Net;

public partial class NotificationClr
public static void InvokeNotificationService(SqlString webUrl, out SqlString outPut)
string commandResult = string.Empty;

HttpWebRequest wr = WebRequest.Create(new Uri(webUrl.ToString())) as HttpWebRequest;
wr.Method = “GET”;
WebResponse response = wr.GetResponse();

commandResult = ((HttpWebResponse)(response)).StatusCode.ToString();
catch (Exception ex)
commandResult = ex.Message;

outPut = commandResult;

STEP 4 : Now we need to generate library from this and register on SQL server.

csc /t:library NotificationClr.cs

If you consider only SAFE permission for the assembly, then above created DLL will be ok. but if you need External_Access or UNSAFE access, then you need to SIGN the dll (Which is explained here

So once you have decided that your assembly needs to be enabled for “External_Access” or “Unsafe”, you have two options. Either set Trustworthy Property of a database to ON or to sign your assembly with a certificate or Asymmetric key . The easiest way is to set the Trustworthy Property of a database to ON, but it’s not good from security prospective. The TRUSTWORTHY database property is used to indicate whether the instance of SQL Server trusts the database and the contents within it. But once you set it to ON , it might open up doors for malicious program. So the best way is to sign your assembly with a certificate or asymmetric key.

Then place the created DLL and  Key file together when you are doing below step.

STEP 5: Register this library on SQL server. here if we use SAFE permission(refer, we don’t have to do much. but in our case we should have web access, which is not coming under SAFE permission.

So all the things we need to do for this i have created as one SQl query, which will create all the necessary things as well as it will handle already existing objects too.

–Important —– Change the DB name and DLL path before execute————–

–enable clr
sp_configure ‘show advanced options’, 1;

sp_configure ‘clr enabled’, 1;

PRINT (‘————–End enable clr————–‘)

PRINT (‘————–start deleting old notification clr if any————–‘)

USE DbName

IF EXISTS (SELECT * FROM sys.database_principals WHERE name = N’NotificationClrLogin’)
DROP USER [NotificationClrLogin]

IF object_id(‘InvokeNotification’) IS NOT NULL
DROP PROCEDURE [InvokeNotification]

IF EXISTS (SELECT * FROM sys.assemblies WHERE [name] = ‘NotificationClrAssembly’)
DROP ASSEMBLY NotificationClrAssembly;

IF object_id(‘InvokeNotification’) IS NOT NULL
DROP PROCEDURE [InvokeNotification]


USE [master]

If Exists (SELECT loginname FROM master.dbo.syslogins WHERE name = N’NotificationClrLogin’ AND dbname = ‘master’)
DROP LOGIN [NotificationClrLogin]

IF EXISTS (SELECT * FROM sys.asymmetric_keys WHERE [name] = ‘NotificationDllKey’)

PRINT (‘————–end deleting old notification clr if any————–‘)


USE [master]

FROM EXECUTABLE FILE = ‘D:\SQL\CLR\NotificationClr.dll’

PRINT (‘—————NotificationDllKey done————–‘)

CREATE LOGIN NotificationClrLogin FROM ASYMMETRIC KEY NotificationDllKey

PRINT (‘—————NotificationClrLogin done————–‘)



USE DbName

CREATE USER NotificationClrLogin FOR LOGIN NotificationClrLogin

PRINT (‘—————CREATE USER NotificationClrLogin done————–‘)

CREATE ASSEMBLY NotificationClrAssembly
FROM ‘D:\SQL\CLR\NotificationClr.dll’

PRINT (‘—————NotificationClrAssembly done————–‘)

CREATE PROCEDURE [dbo].[InvokeNotification]
@weburl [nvarchar](4000),
@returnval [nvarchar](2000) OUTPUT
EXTERNAL NAME [NotificationClrAssembly].[NotificationClr].[InvokeNotificationService]

PRINT (‘—————CREATE PROCEDURE done————–‘)

PRINT (‘—————-End of all commands—————‘)

—-Call WS
–Declare @Response NVARCHAR(2000)
–EXECUTE InvokeNotification ‘http://localhost:8090/Sync/NotifyNow’,
— @Response OUT
— @Response

Now you can call this SP in any place inside SQL server. Then it will call method on the DLL, that method will call REST service URL (here i am passing URL from SQL, so i don’t need to change the dll time to time)

Problem i am still having is, if web service(REST service) and SQL server are on same machine, then it works fine (so URL is localhost). if i tried to call remote web service (or website), then it works 2 times, JUST 2 TIMES. from third call, it starts to time out.

It starts to work again after i restarted sql server. (just 2 calls only). But in the same machine, this works perfectly.

I used following resources to complete this task





If you have any questions about REST service, which i didn’t explained here, please ask in the comments, will explain in another post.

Blank.gif missing error on ReportViewer

Problem : While going through one of our web product, i got a report with a missing image on it. when i check the other reports also, all were having same issue. Reports were developed using RDLC. i was using google chrome. But this issue was not there on IE.  Might be first time i found that IE is working and all other browsers not working.



The html code was like this, related to missing image.



But i checked the report design and blank.gif image is not used anywhere. so i assumed that this should be an issue with report viewer.

I was correct when i checked on google. As mentioned on the below URl, issue with the report viewer.

I used one of workaround, this link mentioned and it is fixed now. that was adding following code to global.asax.

void Application_BeginRequest(object sender, EventArgs e)
// Bug fix for MS SSRS Blank.gif 500 server error missing parameter IterationId
if (HttpContext.Current.Request.Url.PathAndQuery.StartsWith(“/Reserved.ReportViewerWebControl.axd”) &&
!String.IsNullOrEmpty(HttpContext.Current.Request.QueryString[“ResourceStreamID”]) &&
Context.RewritePath(String.Concat(HttpContext.Current.Request.Url.PathAndQuery, “&IterationId=0”));




Categories: Technical Tags: , ,

Installshield LE Dependency dll build issue

November 21, 2013 1 comment

I was trying to make an Win app installer package with installshield limited edition. I added the project primary output and the setup built successfully, it is installed correctly but now the problem is,

Three of the referred projects dlls are properly built, but one project  dll is not latest. meaning that an old version of that dll is built and copied in the setup.

After hours searching on the google, trying rebuilding and trying changing project build order, still couldn’t overcome the issue. But finally this was the solution.

1. Open File option on installshield project. (Setup project –> (2)Specify Application Data –> File)

2. Go to destination computer files.

3. Right click on Primary Output and select ‘Dependencies from scan at build’.

4. That’s It. anyway i hate this new Installshield LE, previous setup and deployment option was much simpler.

(Will add a screen later, right now i am getting error when try to attached image to post. )

Decimal TextBox with jQuery

October 27, 2013 Leave a comment

Problem : I had to work with formatting decimal places for a quantity text box (or label) on a halfway developed project.  I wanted a solution, where i can handle this on one place and applies everywhere with quantity text box.

Solution :

1. Placed this code on the master page, This section will

  • Format all the textboxes content with specific css (QuantityTextBox in this example) on page load,
  • allow to enter only numeric values with one decimal mark. (onkeydown, will call the js function called OnlyDecimalNumbers).
  • after entering the data, input will format on leave (on onblur event)

 var decimalPoints = Number(‘<%: DecimalPoints%>’); //getting number of decimal points from serverside, which user can //defines

$(“.QuantityTextBox”).each(function () {
var originalText = Number($(this).val());

$(“.QuantityTextBox”).live(“keydown”, function (event) {
return OnlyDecimalNumbers(event, $(this));

$(“.QuantityTextBox”).live(“blur”, function () {
var stringValue = $(this).val();
var lastChar = stringValue[stringValue.length – 1];
if (lastChar == ‘.’) {
stringValue = stringValue.slice(0, stringValue.length – 1);

var originalText = Number(stringValue);

2. Added following function on JS file.

//common function to use for allowing only numbers with decimal places. call on onkeydown
function OnlyDecimalNumbers(event, control) {
var existingValue = control.val();
var charCode = (event.which) ? event.which : event.keyCode;

if (event.shiftKey)
return false;

if (charCode == 46 || charCode == 8)
return true;

if (existingValue.indexOf(“.”) == -1 && charCode == 190)
return true;

if (charCode > 31 && (charCode < 48 || charCode > 57))
return false;

return true;

3.  Finally add “QuantityTexBox” css on all the quantity showing/adding textboxes.

Pros on this solution : Can handle all the quantity related formatting on one place, if we have added above css on all the qty textboxes.

Cons : If we need to different CSS per textboxes for styles, we cannot do this, on my situation we were not adding styles directly to textboxes.

EF Navigation Property Looping Issue

This is a problem i faced today, while working on a project which uses EF 4.0.

In my db, there are two tables, say Item and Status. Item’s status is referring status table. Note that there are another tables like ‘Category’, ‘Type’ which are also referred by ‘Item’ table. This table structure wasn’t changed recently and was working fine with EF (4.0 with ObjectContext).  Recently we loaded around 1 million items to Item table for testing. After that, item updating and inserting started to work abnormal way. when i closely look in to matter, it was happening when i assign a value to reference property. As a example,

exitingItem.ItemStatusId = itemStatus;

when i execute first line, it is going loop forever. What i wonder is, this is happening only when i assign value. so this is happening on context. even not before save to DB.

After goggling, i found the exactly same problem on stackoverflow.

This explains what is happening with POCO generated class.

I have a another project, there i used EF5 with DbCotext. when i test the same scenario with same DB, it was working fine. Reason is DbContext does not generate Fixup methods.

Solution : As above link explained, solutions are

  • Remove the Person collection from your AddressStatusLookup class (as you already tried with success). It’s usefulness is questionable anyway.
  • Or: Don’t work with lazy loading
  • Or: Remove the fixup methods from the generated classes. (Perhaps it’s possible to tweak the T4 templates and create a custom template to suppress generating these methods in the first place, but I am not sure.)

With the time frame, disabling the Lazy loading is not possible with us.

removing the navigation property i didn’t consider.

I went with the Removing fixup methods. This was also not straight forward. One article explained to delete fixup generating sections on POCO as this.

If you open the .tt fle, you’ll notice region.Begin("Association Fixup"); (line 303) which ends on line 632. You might want to delete that area and see what you’ll get.

But i had to delete calls to the fixup methods from the property setters, registration of CollectionChanged handlers, and the _settingFK flag from POCO to successfully generate the classes. This way update and insert is happening as normally with 1 million data.

(purpose of fixup is to ensure that each end of a bidirectional relationship stays in sync with the other, but since we use entities via EF context, not interdependently we don’t have to worry for these fixups) 

Debugging Windows Service

January 10, 2013 1 comment

I was working with a windows service nearly one year and hopefully I will be working with this in next couple of months, may be next couple of years due to working on a product based company.  🙂

As most of the developers have experienced, it was a headache to debug a windows service.  So think about working with a same windows service around a yearL. Very beginning I found a solution. That was

  1. Have a key on app.config  as “DebugMode=true”
  2. In the code, I have put following line of code, where I mostly want to debug. (if I want new place, I add same code there) DebugMode value will be assigned based on app.config key.

if (DebugMode)

  1. This was fine. But issue was  with this way is,

Every time I had to compile the code, prepare the setup, uninstall and install on machine. If single line of code changed, had to follow same steps. (Installed version of code and IDE code version should be exactly match)

So today I came up with a better solution. Simple steps. But it saves time, especially when release is nearby :).

  1. Get rid of config key 🙂
  2. Above debug mode property populated by this way. This will get value based on configuration. If we select debug, this will be true and if we select release, this will be false.

public static bool DebugMode




bool isDebugMode = false;


isDebugMode = true;


return isDebugMode;



  1. I will add here whole Main method of Program.cs class. Only we need to change is, select the correct configuration. After finish the debug, select configuration as ‘release’ and build the setup. Don’t be confused with the code. what I do here is,
    1. If debug mode is true, do exactly what I do in the windows service class and start the application. You have to change the project type to ‘console application’ to open the console. But what I wanted here is not to see console, I just wanted to hit the break point without going through set of steps.
    2. If debug mode is false, call the windows service as normally.

static void Main()


if (DebugMode)




string serverURL = string.Format(“http://localhost:{0}/”, ConfigurationManager.AppSettings[“ServerPort”]);

AppHost _appHost = new AppHost();

MiddleWareEngine = new MiddleWareEngine();

MiddleWareEngine.StartEngine();//starting middleware

//Now run the Services.

_appHost = new AppHost();



Console.WriteLine(string.Concat(“Middleware Server Started on “, serverURL));


catch (Exception ex)


Console.WriteLine(“Error: ” + ex.Message);



Else //Release mode


ServiceBase[] ServicesToRun;

ServicesToRun = new ServiceBase[] { new DominateRFIDAlertService() };




Good Bye Visual Studio Installer Projects

December 27, 2012 2 comments

As Microsoft had announced on 2010 , Visual Studio Installer Projects have been removed with latest Visual studio release. (VS 2012).  Recently i was trying to convert our existing VS 2010 solution to vs 2012, got the problem. All the other projects on the solutions were converted successfully and Setup project gave error as project type not installed. At first i thought that i have to create all the setup project from the beginning.  But with few steps, could convert all to ‘InstallShield Limited Edition’ projects.

  1. InstallShield Limited Edition is not installing when we install VS 2012. (I am not sure with other versions, but i use VS 2012 ultimate and it didn’t had InstallShield Limited Edition installed)
  2. Even after installing InstallShield Limited Edition, those setup project will not convert by opening it. (which i thought that way would work)
  3. First open the Vs 2010 solution with VS 2012, it converts all other projects with error of setup project cannot convert.
  4. Remove existing setup project from solution.
  5. open add new project dialog for solution. select the ‘Other project type’ and select the ‘InstallShield Limited Edition Project’
  6. It should not be installed if you didn’t install it previously. so when you try to open the project it will show a message on browser to download the InstallShield Limited Edition
  7. Follow the instruction and download the InstallShield setup. they will send the key to activate to entered email address.
  8. After install, you might have to restart the VS. enter received serial no and activate
  9. Now same as step 5, add InstallShield setup project and on the InstallShield menu on main menu, select ‘Visual Studio Deployment Project Import Wizard…’
  10. Select your vs 2010 setup project file.  Hopefully it will convert without error. i didn’t had to do any changes on converted project.


How to avoid ‘WebForms.PageRequestManagerServerErrorException’ error

December 9, 2012 Leave a comment

This error i got suddenly, when i use partial post back to server on aspx page. this page was working perfectly for months and today only i got this.  After looking into this sometime, only thing has changed here is now i have more data on the page.  But there is no way to catch the error and visual studio is returning this error when i click any control on the page.


When i look on the windows event log, exception was logged there as,

Operation is not valid due to the current state of the object.
at System.Web.HttpValueCollection.ThrowIfMaxHttpCollectionKeysExceeded()
at System.Web.HttpValueCollection.FillFromEncodedBytes(Byte[] bytes, Encoding encoding)
at System.Web.HttpRequest.FillInFormCollection()

What has happen was because of more data on the page, It is generating  “ThrowIfMaxHttpCollectionKeysExceeded” error.

To overcome this issue you have to add following key to web.config as follows,

   <add key=”aspnet:MaxHttpCollectionKeys” value=”2000″></add>

P/S : After looking into this issue on the web, i found this information,

 Microsoft released a security update KB2656356 / MS11-100 for ASP.NET to address a potential Denial of Service vulnerability.  In the update, Microsoft introduced a limit to the number of data elements on an ASP.NET form.   The default limit is 1000 data elements.   Exceeding the limit will cause a ThrowIfMaxHttpCollectionKeysExceeded error.

After applying the patch to your webserver, forms that exceed the limit will generate the following error when posting:

Categories: Career, Technical

Programming in HTML5 with JavaScript and CSS3 (Exam 70-480)

November 27, 2012 Leave a comment
If you are interested to complete above mentioned exam, this is good chance.   is offering a free exam voucher for this. Bellow i have added the voucher code and some information.  you can go to their web site and get more information if needed.
FREE EXAM VOUCHER FOR 70-480! | Register now to take Exam 70-480 Programming in HTML5 with JavaScript and CSS3 for FREE! Just use this voucher code when scheduling your exam: HTMLJMP (voucher code available through 3/31/2013 or while supplies last.)
This is very latest exam which was published on august. So cannot find much resources and even still microsoft have not provided official book for this exam .(according to my knowledge) but most of people using “Microsoft_Press_eBook_Programming_Windows_8_Apps_with_HTML_CSS_and_JavaScript_Second_Preview_PDF” ebook and Pluralsight Videos.
I have gone through some of the available materials, seems to be very interesting because HTML 5 is new trend on the industry.  I will list some other links, which i am referring.  Go through those and register for the exam if you are interested.

What’s New in Visual Studio TFS 2012

September 9, 2012 Leave a comment

While playing with new TFS which comes with visual studio 2012, i got to know that it is now having more support for agile methodologies.  Rather writing my own post about new TFS 2012, i found a very good and organized article, which describe everything with TFS 2012.

Before buy it, you can try it with . Site itself explaining new features and how to use it. i created test project under TFS Preview, created few test tasks, added few classes on VS under that task, used code review, TRIED with creating with build. Just simple test. but feel new TFS is awesome.