Также вы можете попробовать, добавив элементы с плавающей точкой в ваш CSS.Вот исправление для вашей проблемы.Я удалил некоторые свойства из вашего CSS и добавил несколько.Следующим будет ваш CSS.
#header, #footer { border: 1px solid red; padding: 10px; font-size: 20px; }
#contents { position: relative; background: url(../img/sidebar.gif) repeat-y; }
#contents .sidebar { width: 220px; padding: 20px; float:left}
#contents .body { padding: 20px 20px 20px 0; margin-left: 280px; border: 1px solid green; }
.clearfix:after { content: "."; display: block; height: 0; clear: both; visibility: hidden;}
И вам нужно добавить класс "clearfix" в ваш HTML.
<div id="contents" class="clearfix">
Спасибо, Рамеш