Archive for the 'howto' Category

How to reveal stored passwords and let browser remember them

Tuesday, August 28th, 2007

There is all so common situation when you have to go to once a week to a website, and you have to login to it and your browsers is not asking you about remembering that password. So you have to remember that password and its getting out of your head and you have to spend some time trying to get it into your head again.

If you are using Firefox you are lucky. There is a way to let your browser to remember the password and even reveal what you have typed correct password.

Here are the steps for a freedom:

  1. You will need to install Greasemonkey extension for Firefox from here. This extension allows you to use special JavaScript programs, which change the behaviour and/or look of the web sites. Don’t worry if you don’t know JavaScript, that knowledge is not required unless you want to write something completely new.

    Perhaps you want to bookmark this page before the required Firefox restart, so you could easily return to this small guide. Press Ctrl-D to do that.

  2. After Greasemonkey is installed and you restarted the Firefox you will need to install Force Autocomplete script, which will enable password saving feature on all pages.

    You don’t have to restart Firefox, to get Greasemonkey scripts working. If the script is not working - just refresh the page (Press F5).

  3. Next step is to install password revealing script: Passwords on MouseOver

Now you all set. Your form data will be remembered and you could verify that you are typing correct password.

You could get many more additional scripts here: http://userscripts.org/

Subversion and branching

Sunday, December 3rd, 2006

Excellent article on branching in Subversion. One thing missing is the branch timeline chart. Something like this:

Where horisontal line is the trunk timeline and angled lines are releases. Based on my experience, that chart often helps developers to understand when branches are created and how to deal with them.

Creating WebSphere 6 application MBeans

Friday, January 20th, 2006

This is a little step by step guide on how to create and register custom service with JMX interface on WebSphere:

1. Create class, which implements two interfaces:

JAVA:
  1. com.ibm.websphere.runtime.CustomService
  2. com.ibm.websphere.management.JMXManageable

2. Implement "initialize" method (inherited from CustomService)
This method has a parameter, Properties, which will contain properties defined via WS Administration console. We are interested in one property: externalConfigURLKey. This property contains path to external configuration file (if any is needed).

This is how to get the path:

JAVA:
  1. public void initialize(Properties configProperties) throws Exception {
  2.  readConfig(configProperties.getProperty(externalConfigURLKey));
  3. }

3. shutdown() method may be left blank.

4. implement getType() method (inherited from JMXManageable):

JAVA:
  1. public String getType() {
  2.  return "MyMBean";
  3. }

Remember the name you returned here!

5. implement getMBeanProperties:

JAVA:
  1. public Properties getMBeanProperties() {
  2.  Properties props = new Properties();
  3.  props.put("SpecialProperty", "value");
  4.  return props;
  5. }

I think this will return a list of properties, not declared in MBean descriptor. Read only, of course, since there is no setMBeanProperties() method.

6. implement getters and setters for properties you want to expose:

JAVA:
  1. public String getUserName() {
  2.  return this.userName;
  3. }
  4.  
  5. public void setUserName(String param) {
  6.  this.userName = param;
  7. }

7. Create MBean descriptor file, for example myTest.xml.

XML:
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE MBean SYSTEM "MBeanDescriptor.dtd">
  3. <MBean type="MyMBean">
  4.     <attribute name="UserName" type="java.lang.String" getMethod="getUserName" setMethod="setUserName" />
  5. </MBean>

IMPORTANT: Make sure that type matches the value you remembered on the step 4!

8. Compile and package. Create .jar, having descriptor in the root. Place .jar somewhere accesible for WebSphere.

9. Start WebSphere and open Administration console.

10. Go to Servers - Application Servers - yourserver - Server Infrastructure - Administration - Administration Services

11. Click on "Extension MBean providers"

12. Click on "New"

13. In the "Classpath" entry type the full path and name of your jar (created on step 8)

14. Type something memorable in two other fields and click Apply.

15. Click on "Extension MBeans" (on the left)

16. Click on "New"

17. Enter the name of MBean descriptor file (see step 7.)

for example:
myTest.xml

18. Enter the type name of your MBean. IMPORTANT: must be the same name as it was on steps 4 and 7.

19. Click Apply.

20. Go to Servers - Application Servers - yourserver - Server Infrastructure - Administration - Custom Services

21. Click New

22. Place check on "Enable service at server startup".

23. Enter full class name (with package) of your MBean class (the one we created on step 1) into "Classname" field.

24. Enter something memorable in "Display Name"

25. Enter fill path and file name of the jar file (step 8) into "Classpath".

26. If your service requires configuration file (step 2) enter full path to it into " External Configuration URL"

27. Click on Apply.

28. Click on Save (on top)

29. Click Save.

30. Restart the server.

Here are the commands, used to verify MBean from admin console:

To run console:
wsadmin.bat -conntype SOAP -port 8881

To make sure that MBean started:
$AdminControl queryNames *:*,type=>

Store MBean in Tcl variable:
set mybean [$AdminControl queryNames *:*,type=MBeanName]

See MBean description:
$Help all $mybean

See MBean attributes and values:
$AdminControl getAttributes $mybean

Set specific attribute:
$AdminControl setAttribute $mybean UserName mike

Bad Behavior has blocked 45 access attempts in the last 7 days.