Sunday, December 6, 2009
Wordpress
http://vbguru.wordpress.com
Friday, December 4, 2009
Inheritance, and why it rocks!
Here we create our 'base' class. We declare it as MustInhert so that we can use the MustOverride property on the ProcessCard Function
You'll notice that we created a function signature, but it has no code attached. We add the code later when we create the gateway's class.
When your create your class that inherits your base class you'll notice when you add the line 'Inherits CreditCard' that it will autofill the MustOverride Function. Visual Studio makes it easy for you!
Your other team members will love you if you now use a 'wrapper' to manage the gateway, check this code out:
Now your UI guy just has to write something like this and he never has to worry about which credit card processing gateway you are using.
Thursday, December 3, 2009
Using a One-Way Hash on Passwords
Public Class Hash
Private Function ComputeHashValue(ByVal data() As Byte) As Byte()
Dim hashAlg As System.Security.Cryptography.SHA1 = System.Security.Cryptography.SHA1.Create()
Dim hashvalue() As Byte = hashAlg.ComputeHash(data)
Return hashvalue
End Function
Public Function HashPassword(ByVal password As String) As String
Dim encoder As System.Text.UTF8Encoding
Dim b() As Byte
encoder = New System.Text.UTF8Encoding
b = encoder.GetBytes(password)
b = ComputeHashValue(b)
Return Convert.ToBase64String(b)
End Function
End Class
Wednesday, December 2, 2009
Being Good With SQL, Using SQL Cursors
Today I wanted to talk for a moment about using SQL cursors, because they are very cool. Have you ever wanted to do a loop inside a Stored procedure? Well check out this code, you this will loop through all users that do not have a locker assigned (using a cool "NOT IN" SQL statement) and assign each of them the next available locker.
Tuesday, December 1, 2009
Threading
#1) Threading
#2) Registry Access
Back in my VB6 days my team tried many times to get things to work muti-threaded, there were magazine articles at the time that claimed to be able to do it using windows API hacks, and MDI forms, but we were never able to get it to work. In .NET you just have to call .Start on a thread object is just Amazing.
Registry access in VB6 was crazy. You had to write pages and pages of code using a bunch of Win32 API Calls. In .NET I changed my pages of code into just a few lines. Once I wrote my first .NET Registry access routine I never wanted to write in VB6 again.
Here is some code that I modified that does both Registry Access and threading. I'm not sure who wrote this code originally, but I modified it so it would be thread safe. Your form needs to have the following controls:
A timer named Timer1, set to go off every 5 seconds (5000 ms)
A datagrid control named DataGridView1
Two buttons Button1 and Button2
This code does have a bug that I didn't take the time to figure out, after it searches 200,000 or so keys it starts crashing. I'm not sure why, my guess is it is trying to access some System Protected Key, but this code works well enough that I am not going to worry about that.
Now that you've seen that I would like to discuss some of the concepts that you need to be aware of in Threading.
Mainly "Thread Safety" and "Thread Management".
"Thread Safety"
Most people new to threading do not think much about this, you spawn some thread and want to post it's results back to the UI. But you will find when you code tries to access a datagrid, or listbox that is on the UI thread that it will throw an error as a background thread will not be allowed to mess with the UI thread. There are a number of solutions to this, I generally use the Singleton pattern to create a buffer to hold data in. I'll talk more about Singletons in later posts. For this example I decided to use the timer control to pause the background thread, and update the UI with it's current results.
"Thread Management"
This concept is important as well. If you do not stop your other threads when your application is shut down they will keep running forever. You also need to be concerned about how many threads you create. The first time I wrote a threading application I wrote a program which searched all files and folders on a hard drive. The main thread searched for new folders, and it spawned another thread to search the files. As it ran it just kept spawning thread after thread until it hit around 32,000 threads at which time my computer, without giving an error message, turned itself off. In this example we only create one thread so you need not worry about it crashing you computer.
I generally create my own threading class which spawns a set number of threads (usually in it's constructor) and manages them. It keeps a Queue of new things to spawn threads for, and then checks the status of each thread, once the thread is done with it's task the threading class records the results, disposes the thread and creates a new thread with the next task in it's Queue. I believe this is called "Thread Polling" but I don't know I created this method on my own without reading about it.
i += 1
Monday, November 30, 2009
Create a variable without Dim
Do you ever Dim i as Int and use it over and over again, just to realize that you forgot to set i = 0 before one of your loops? Well fear no more, you can create a variable named i without diming it and it only lives inside a narrow scope. Check this out:
For i As Integer = 0 To 10
Next
You can even Dim a variable inside a IF Block (or any other block) and it is only available in the scope of that block.
If True = True Then
Dim i As Integer = 0
i = i + 1
End If
If True = True Then
Dim i As Integer = 0
i = i + 1
End If
Best tool to post Source Code
http://copysourceashtml.codeplex.com/
After you install it in the edit menu and the right-click context menu inside Visual Studio you get a new option that says "Copy As HTML.."
Here is a line with a bunch of colors:
dt.Columns.Add(New System.Data.DataColumn("Field", GetType(String)))
Thursday, November 26, 2009
UAC Administrator Access
Well in Visual Studio 2008 it is very easy:
Right click on your project and press the button for "View UAC Settings"
Change the Level to:
level="requireAdministrator"
SQL CE Takes too much Memory
----- (POST #1)
I have an MC 1000. At first I thought it was perfect, ultra low cost, and no extra features that were never used. At first they run perfectly, but after you insert a few hundred records into its CE Database it starts running slower and slower until it is almost unusable. I have the users reboot the device and it runs fine again for a while but does the same thing again. All my code is doing is adding records to the SQL CE DB.
Anyone have similar problems? I am thinking of switching over to a XML file instead of SQL CE.
I have converted as much storage memory into program memory and it has helped, but only for a while.
----- (POST #2)
I came across the following MS Article while researching this problem:
http://support.microsoft.com/?kbid=842191
It mentions:
Q17: Does setting my ADO Recordset to 'nothing' reclaim any memory?
A17: Generally, the answer is "yes." However, Microsoft recommds that all your applications use set rs=nothing and set cn=nothing when you are finished using them. Database engines can take a fair amount of memory, and it is best not to leak memory.
Usually, Microsoft Visual Basic eventually releases the memory. However, there have been some cases where the memory is not released quickly enough and you can run out of memory on the device, especially if you have a particularly bad memory leak.
Made me think: am I setting all my objects to nothing? I went through my code and found that although I was setting all my Connections = Nothing I wasn't setting the SqlCeCommand Objects to nothing when I was done with them. I added a few cmd = Nothing lines and now my App runs Faster then ever and doesn't seem to be stopping for anything.
Whoo!
Wednesday, November 25, 2009
Visual Studio 2008 Locks or Freezes in ASPX
http://abdullin.com/journal/2009/5/12/visual-studio-2008-locks-or-freezes-in-aspx.html
What worked for me was finding:
C:\Program Files (x86)\Common Files\microsoft shared\
OFFICE12\Office Setup Controller\Setup.exe
I ran it as an administrator and told it to do a repair. Once this was done not only did Visual Studio stop locking up, but loading the ASPX pages is faster as well.
Tuesday, November 24, 2009
Dim x as New
Sometimes when I am lazy I still use "AS NEW" but I think it's a bad habit, and should never appear in 'good' code.
A small rant
Like I said If I am guilty of doing this let me know, but I always try to keep it in mind when posting code.
Generate a Unique ID
Note that I used the keyword "Shared" by doing this your code can get an ID without creating a new object.
The SyncLock Command makes sure only one thread can access it at a time.
The Sleep one millisecond command makes sure if two threads requested data at the same time, they both get different ID's.
Public Class UniqueID
Public Shared ReadOnly Property Generate() As String
Get
Dim UniqueID As String
SyncLock "GENID"
System.Threading.Thread.Sleep(1)
Dim d As String = Now.DayOfYear
Dim y As String = Now.Year
Dim h As String = Now.Hour
Dim m As String = Now.Minute
Dim s As String = Now.Second
Dim ms As String = Now.Millisecond
If d.Length = 1 Then d = "00" & d
If d.Length = 2 Then d = "0" & d
If h.Length = 1 Then h = "0" & h
If m.Length = 1 Then m = "0" & m
If s.Length = 1 Then s = "0" & s
If ms.Length = 1 Then ms = "00" & ms
If ms.Length = 2 Then ms = "0" & ms
UniqueID = y & d & h & m & s & ms
End SyncLock
Return UniqueID
End Get
End Property
End Class
Monday, November 23, 2009
Using Ajax To Avoid Timeouts
First thing you do is you have to add a ScriptManager to your page. This is easy to do, it's found in the VS UI tool menu under AJAX Extensions. You don't have to do anything with it other then drop it on your page. You Can edit the AysncPostBackTimeout property if you know your tasks are going to take a while.
Then drop in a AJAX UpdatePanel. This is where the magic happens, anything you put inside this box, say like a command button, when pressed will not cause your entire page to do a post back. You can drop in a Label and update it's text without having to reload the whole page.
Add a AJAX UpdageProgress control and you can put some text in it like "Please wait while your request is processed.." and bam, you have a user message that will be displayed while the AJAX process is running.
One little trick about if you use a Button, I added this code so that the user can't press the button twice:
Button1.OnClientClick = "this.disabled = true;__doPostBack(this.name,'')"
It's really that easy. Here is some code:
<asp:UpdateProgress ID="UpdateProgress1" runat="server" AssociatedUpdatePanelID="UpdatePanel1"> <ProgressTemplate> Processing.. Please Wait </ProgressTemplate> </asp:UpdateProgress> <asp:UpdatePanel ID="UpdatePanel1" runat="server"> <ContentTemplate> <asp:Button ID="cmdProcess" runat="server" Text="Process" onclick="cmdProcess_Click"> </ContentTemplate> </asp:UpdatePanel>
Soap Client Timeout WebServices
I have a web service which is taking in a tab delimited data file and put it into a SQL database. But I had problems, my web browser kept timing out before the processing was done. Oddly enough the web service finishes the task anyway, but I have a user issue with them getting an error message.
So the fist thing I did was I used AJAX to place a message on the screen that the file was being processed and I set the AysncPostbackTimeout in the Script Manger to 0 so it would never time out. But this only solved one problem, the bowser stopped displaying an error message, but the underlining call was still dieing, and so I could not update the web site once it was done.
To fix that I updated the InnerChannel.OperationTimeout to an hour by doing so:
(Web Service Soap Client).InnerChannel.OperationTimeout = New System.TimeSpan(1, 0, 0)
This makes it wait an hour before it gives a timeout error (more then enough time)
I should change all the values to 5 mins as that now if there really is an error It will make the user wait an hour.
My VB Blog
I don't know why you would want to program in any other language. It's fast and easy, and with Visual Studio's amazing intellisense I'd never switch to a different platform.